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1 . A method for representing an article of manufacture having a piuraliT>' of 
sxruciural design variants comprising the steps of: 

defining a pluralit}' of positions ( 1 2) each corresponding to a different predefined 
location on the article of manufacture; and 

assigning at least one position variant (16) to each position, each position variant 
(16) identifying a specific part that may be used at the respective position (12) in accordance \svh 
a particular design variant so that, in a particular article of manufacture, only one of the at least 
one position variants can be selected for the respective position. 



2, The method of claim 1 , further comprising the step of: 
defining a plurality of links (14) each between panicular pairs of positions/^ach 
link (14) corr^onding to a physical connection between parts in a pair of locations in^e anicle 
of manufacture. \^ch pair of locations corresponds to the respective pair of posi|ions. 

o. 1 ns method of claim 2, further comprising the step < 
assigning at ieto one connection variant (16) to each ii^ (14), each connection 
variant (16) specifying a particui^smethod of joining a part in a first position of the respective pair 
of positions to a part in the other pos^on of the respective pair p4 positions. 

4, The method of claim zis|urther corn^rising the steps of: 
assigning at least one connection a^i;^^ ^16) to each link (14); 
assigning to each connection variant J(\ 6)^t least one of functional data, structural 
data, part supplier data, group membership data^^d finan<^t^ data. 



5. The method of clmm I , further comprising th^^^ps of: 
formulating a code rule (22) for each position variant (lo^ndicating when die 
particular variant (16) should be selected in accordance with specified design^bjjtions; 

identifying the^code rule (22) for each position variant ( 1 6) assignra^ a specific 

position; 

deteijmning any overlap in scope between the identified code rules (22); anS 
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overlap 



,!^<r A method for manufacturing an anicle of manufacture having a plurality 
of structural design variants comprising the steps of: 

defining a plurality of positions (12) each corresponding to a different predefined 
location on the anicle of manufacture: 

assigning each position a unique position ID; 

assigning at least one position variant (16) to each position, each position variant 
(16) identifying a specific pan that may be used at the location corresponding to the respective 
position and having a related code rule (22) indicating when the particular variant (16) should be^ 
selected in accordance with specified design options; 

upon receiving an order (56) containing specified design options: 

evaluating the code rule (22) for each position variant (16) to select a 
specific position variant for each position and thereby identify a specific pan for use in the 
location corresponding to the respective position; 

providing the specific pan associated with each selected position variant; 

and 

manufacturing the article of manufacture using the specific parts in the 
corresponding locations. 



7. The method of claim 6, furmer comprismg the Kieps ufr 
defiitkig a plurality of links (14) each between particular pairs of positions (12)/^^ 
each link (14) correspon^lg^o a physical connection between parts in a pair of locations^^ the 
article of manufacture, which pair'SW^cations corresponds to the respective pair oppositions (12); 
and 

assigning at least one conneOTan variant (16) Jo at least one link (14), each 
connection variant (16) specifying a particular metMa^ct^ining a first pan in a first position of 
the respective pair of positions to a second par^iii"the oth^^fi^ition of the respective pair of 
positions, each connection variant (16)^having a related code rul^422) indicating when the 
particular connection variant shouid be selected in accordance with specifiga^desien opnons. 
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The method of claim 7. funher comprising the step ot: 
evaluaims^^th^code rule (22) for each connection variant (1.6)-to^ identify an 
appropriate method of joining the idehtiiied parts for the corresggnditigpair of positions (12) in 
response to the receipt of an order containing spfei^rfiSesign options; and 

the manufacturing stegjc-ofmprising the step^&f«^ing the identified method to join 
the respecti\'e identified ps 



"2, ^ A method for determining manufacmring pans requirements to produce an 

article of manufacture having a plurality of strucniral design variants in accordance with at least 
one order (156) specifying particular design options, the article of manufacture being described 
in a bill of materials (BOM) (100) containing a plurality of position variant definitions (16), each 
position variant definition (16) being assigned to a panicular position (12) corresponding to a 
physical location in the anicle of manufacture, each position variant (16) further identifying a 
specific part and including a code nile (22) indicating v/hen the identified part should be used at 
the location conresponding to the particular position (12), the method comprising the steps of: 
extracting unique code rules from the BOM (101); 

evaluating each tmique code rule in accordance with the design options for each 

order (156); 

mapping the evaluations of the unique code rules to the corresponding code rules 
(22) in the position variant definitions (16) in the BOM (100); and 

determining the appropriate position variant (1 6) to select for each position (12) 
in accordance with the mapped code rule evaluations. 



10. The method of claim 9, wherein: 

ie rule (22) comprises at least one code rule element (J^4ycorTesponding 
to a selectable design optiraXK^J; and 

the orders (1 56) are contailiedjn an order mapiscfl 20) which cross references each 
order against every code rule element. 



1 1 . The method pfrlaim 1 0, wherein the step of evattiatmg each imique code 
rule comprises the steps of:^ 

dmiiidg each imique code rule into its discrete code rule elements (124)T 
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linking each discrete code rule element ( 1 24) with order data for the corresponding 
code rule client in the order matrix ( 1 20); and 

e^luating each unique code rule (22) in accordance with the order data li^^ed to 
the associated discrke code rule elements (124). 

1 2. The^ethod of claim 1 1 , wherein the step of dividing each i^fUque code rule 
comprises the steps of: 

factoring each uil^que code rule into one or more simpler co/^e rule components; 

and 

di\ading each code nil^ component into one or more cjjicrete code rule elements 

(124): and 

the step of evaluating each Wique code rule furrifer comprising the steps of: 

e\-aluating each code r^ie componcn^n accordance with the order data 
linked to the associated discrete code n^le elemenjfes (124); and 

e\*aluating each unique code ful^m accordance with the evaluated code rule 

components, 

13. The method of clain/^IO, wher^ each position variant (16) has an 
associated validit>' period and the step of exttacting unique cdde rules comprises extracting unique 
code rules only from those position variants (16) which have n9t expired at a specified start time 
based on the validity period. 



14, The xnethod of claim 13, wherein a sequence olRorders in the order matrix 
(120) indicates a time sequence of manufacture, the method further omiprising the steps of 
determining, in accc»oance with the specified start time, a build time ^en the article of 
manufacture assodated with each particular order will be manufactured; 

ae step of mapping comprising mapping the evaluations of the uni^e code rules 
to the corpdsponding code rules (22) in the position variant definitions (16) onlykfor those 
panicuH^ orders which have a build time within the validity period of the respective m^silion 
van^t. 
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.^fdaim 13* further comprising th^ 



repeating the 



mapping st^p upon receipt of a resequencedo^^m^SSFtesdgf^ revised manufacturing parts 
requirements in^coganas v^ ffai tne r e<i PqTi rnreri matrix. 



A method for generating documentation for an article of manufacture 
having plural structural design variations comprising the steps of: 

defining a pluraiit>* of positions (12) each corresponding to a different predefined 
location on the article of manufacture; 

assigning at least one position variant (16) to each position (12). each position 
variant idenrifying a specific part that may be used at the location corresponding to the respective 
position in accordance with a panicular design variation, so that, in a particular article of 
manufacture, only one of the at least one position variants can be assigned to the respective 
position; 

assigning component documentation data to a predetermined set of position 

^'ariants (16); 

defining at least one assembly to be docimiented, said assembly comprising a 
plurality of positions (12) and having a plurality of design variants (16); 

upon receipt of a customer order (156) specifying selected design options: 

determining the specific assembly design variant defined by the selected 

design options, 

aggregating the documentation data assigned to the positions in the assembly, and 
storing the aggregated documentation data. 



ler comprising 



connection documentation data 

the step o: 
data assigned to 



fbetweer 



assignmg 

positions (12); and 

gating documentation 
between pairs of positions (12) in the assemblyT 



5f aggrej 



ler comprises the^ 



A system for generating a bill of materials (BOM) (100) representing the 
parts used in an article of manufacture having a plurality of structural design variants comprising: 
a computer having a processor and a memory; 
the memory containing computer code configuring the processor to; 
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receive a plurality of position defmiiions (12) each corresponding to a 
different predefined location on the article of manufacture; 

receive assignments of at least one position variant (1 6) to each position 
(12), each position \'ariant (16) ideniif>-ing a specific part that may be tised at the location 



each position variant (16) further including a code rule (22) indicating when the particular 
variant should be selected in accordance with specified design options; 

identify' the code rules (22) for each position variant (16) assigned to a 
specific position: 

determine any overlap in scope bet^^'een the identified code rules: 

adjust the identified code rules (22) to remove at least some of the 
determined overly: 

generate a BOM { 1 00 ) including said plurality of positions (12), assigned 
position variants (16). and adjusted code rules (22); and 

store said BOM (100) for use in determining manufacturing parts 
requirements for producing particular design variants of said article of manufacture. 



Q A system for use in manufacturing an article of manufacture having a 

plurality of structural design variants, the system comprising: 
a computer having a processor and a memory; 

the memory including information representing a bill of materials (BOM) (100) 
containing a plurality of position variant definitions (16), each position variant definition (16) 
being assigned to a pardcular position (12) corresponding to a location in the article of 
manufacture, each position variant definition (16) further identifying a specific part, and including 
a code rule (22) indicating when the position variant ( 1 6) should be selected and thereby when the 
identified part should be used at the corresponding location; 

the memory further including information representing at least one order (154) 
specifying particular design options which define a parricxilar design variant of the article; 
the processor being configured to: 

(a) evaluate the code rules (22) for each position variant ( 1 6) in accordance 
with the respective design options for each order (156) to identify an appropriate part for 
use in each location of the corresponding particular design variant of the article; and 



corresponding to the respective position in accordance with a particular design variant. 
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(b) produce an output indicating for each order ( 1 56) the appropriate pans 
for use in the corresponding particular design variant of the anicie: 

the particular design variant defined by a specific order being manufactured using 
the parts indicated for that specific order. 



-20: 1 he system or claim i y . wherein the processor is contigured to evShiar?:fl5f 

code rules 

e?h{acting unique code rules from the BOM (100); 

evaii^ng each unique code rule in accordance with the design options for each 

order (156); 

mapping thKevaluations of the unique code rules to the coirresponding code rules 
in the position variant definimms (16) in the BOM (100); and 

determining the stppropriate position variant (16) to select for each position (12) 
in accordance with the mapped coo^ rule evaluations. 

21 . The system of cla^m 20, wherein: 
each code rule (22) comprises at least one code rule element; 

each design option corresponds to a respective code rule element (124); and 

V' 

the orders ( 1 56) are containedin an order matrix ( 1 20) which cross references each 



order (156) against the code rule elements (124);\ 

\ 

the processor being further configur5^d to evaluate each unique code rule by: 

\ 

dividing each umque code rule into its discrete code rule elements (124); 

\ 

linking each discrete code rule element (124) with order data for the 

corresponding code rule element in the order matri^ (120); and 

\ 

evaluating each imique code rtile in accordance with the order data linked 
to the associated discrete code rule elements (124). \ 



22; The system of claim 21 , wherein: ^^ 

the processor is configured to divide each unique code r^ by factoring each 

imique code rule into simpler code rule components and dividing the code nii^ components into 

discrete code rule elements (124); 
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"tfan^P^g^^^Q^HmF^^ to evaJuat e each code rule coSms^nrnT 

accordance with the order data linked to the associated discrete code rule element^24) and 
evaluate each unique code rule (22) in accordance with the evaluated code rule odmponents. 



23. \ The system of claim 20, wherein each position v^nant has an associated 
vaiidit>- period: and \ 

the processoVi^configured to extract unique code/oles only from those position 
variants (16) which are not expi^d at a specified start time ^accordance with the associated 
vaiidit}' period. 



24, The system of claim 2S, v/l^cin: 

the orders (156) are contained order manrix (120) stored in memory wherein 
the sequence of orders in the order matrix Q20) indies a time sequence of manufacture of said 
orders; 

the processor being f&rther configured to: 

determiMC in accordance with the specififed stan time, a build time when 
the article of manuf^re associated with each particular or^wiil be manufactured: and 
ip the e\-aluations of the unique code rules to^e corresponding code 
rules (22) in^e position variant definitions (16) only for those pahicuiar orders (156) 
which h^e a build time within the validity period of the respective pos^lS^variants. 

25. The system of claim 23, wherein the processor is configured to repeat the 
n^pf^g procedure upon receipt of a resequenced order matrix to thereby provide reWd 



-mag^^gemtrtg Ttq mttnmts in aceordanc^ w igScrasequmced o 




Adatastructure for storing in a computer readable medium a representation 
of an article of manufacture having piural structural design variants, the datastnicture comprising: 
a plurality of data positions (12), each corresponding to a predefined location in 
the article of manufacture; 

at least one position variant (16) assigned to each position (12), each position 
variant (16) including a first field containing pan identification data (102) and a second field 
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conuining a code rule (22), the code rule indicating when the part identified in the first field is to 
be placed in the location associated with the respective position (12). 

^"^•^^ 2?: The data-^t nicture of claim -^gr^rtherLcoinmsing: 



\5Lt least one link (14) between a first position and a second position, the link 

\ 

indicating a physical connection between a first part at a first location associated with the first 
position and a second pai:^t a second location associated with the second position; 

at least one cbnnection variant (16) assigned to each link (14), each connection 
\'ariant including a first field conbdning process information related to the joining of the first pan 
and the second part and a second fiefd^coniaining a code rule (22); the code rule (22) indicating 
when the process infonnation in the first fi^Id is appropriate for use in assembling a particular 
desian variant of the article of manufacture. 




28. The data structure of ciairn 16, farther comprising: 
a pltirality of links (14) each between a res^ctive first position and a respecdve 
second position, each link indicating a physical connection between a first part at a first location 
associated with the respective first position and a second part at a scbond locarion associated with 
the respective second position; ^ 



each connection variant including a group identifier field^QS) associating the 



E , A computer program for representing an article of manufacmre having a 

plurality of structural deagn variants, said program being stored on a storage medium and 
comprising: 

a program module defining a plurality of positions (12) each corresponding to a 
different predefined location on the article of manufacture; and 

a program module assigning at least one position variant ( 1 6) to each position, each 
position variant (16) identifying a specific part that may be used at the location corresponding to 
the respective position (12) in accordance with a particular design variant, so that in a particular 
article of manufacture, only one of the at least one position variants can be selected for the 
respective position. 
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~*5~C~~~~^-eompHterprogrHnr£rf^^ 
defining a pluralit>'\pf links (14) between particular pairs of positions (12), each link/l4) 
corresponding to a phV^icai connection between parts in a pair of locations in the article of 

\ 

manufacture, which pair oXlocaiions corresponds to the respective pair of positions. 

'\ / 

3 1 . The computer program of claim 30. fimher comprising ajfrogram module 
assigning at least one connection \<ariant (16) to each link (14), each conn&tion variant (16) 
specifying a particular method of joining a pan in a first position of the resp^ti ve pair of positions 
to a part in the other position of the respective pair of positions. 



32. The computer program bf claim 30, fiirthe/comprising: 
a program module assigning at lea^t one conneciion variant ( 1 6) to each link (14): 

and \ 

a program module assigning to each variant (16) at least one of 

functional "data, strucniial data, part supplier data, grobp^ipembership data, and financial data, 

. \ 

33. The computer program of^^ claim 29, futtjier comprising: 

a program module recei\'ing/a code rule (22) Vpr each position variant (16) 
indicating when the particular variant siuMd be selected in acco^ance with specified design 
options; 

a program module identifying the code rules (22) for ea^h position variant (16) 
assigned to a specific position {L 

a program modufc determining any overlap in scope between^the identified code 
rules; and / \. 

a program niodule adjusting the identified code nales to remove at Wt some of 
— ifae-dgtemm cduveilap. 

3 ^ XT A computer program for manufacturing an article of manufacture having 
a plurality of structural design variants, said computer program being stored on a storage medium 
and comprising: 

a program module defining a plurality of positions (12) each corresponding to a 
different predefined location on the article of manufacture; 
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a program module assigning each position a unique position ID; 

a program module assigning at least one position variant (1 6) to each position ( 1 2), 
each position variant (16) identifying a specific part that may be used at the location 
corresponding to the respective position and having a related code rule (22) indicating when the 
panicular variant should be selected in accordance with specified design options; 

a program module which, upon receiving an order (156) containing specified 

design options: 

evaluates the code rules (22) for each position variant (16) to identify an 

appropriate part for use in each position: 

provides the specific part associated with each position variant (16): and 
confrols manufacture of the article of manufacture, using the specific part 

in the corresponding location. 



rogram module defining a plurality of links ( 1 4) each between particmar pairs 
of positions (12), eahh link corresponding to a physical connection between p^tsun a pair of 
locations in the article offMnufacmre, which pair of locations corresponds tp^e respective pair 
of positions; and 

a program moduie^signing at least one connectioifvariant ( 1 6) to at feast one link 
(14), each connection variant (16) sp^fying a particular mraiod of joining a first part in a first 
position of the respective pair of positioi^to a second^m in the other position of the respective 
pair of positions, each connection variant ( 1 6) c^ang a related code mle (22) indicating when the 
particular connecdon variant should be seie^ira in^cordance with specified design options* 



36. The computer/program of claim 35, nmfter compnsmg: 
a program moduk^valuatiiig the code rtdes (22jfor each connection variant (16) 
to identify an appropriate mdmod of joining the identified parts mi:^the corresponding pair of 
positions in response tq^me receipt of an order (156) containing specified design options; and 
the pmxufacturing program module using the identified i^|hod to join the 



respective idenu&d parts. 
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A computer program for determining manufacturing parts requirements to 
produce an anicle of manufacture having a plurality of structural design \'ariants in accordance 
with at least one order ( 1 56) specifying panicular design options, the article of manufacture being 
described in a bill of materials (BOM) (100) containing a plurality of position variant definitions 
(16), each position variant definition being assigned to a panicular position (12) corresponding 
to a location in the anicle of manufacture, each position variant fiinher identifying a specific pan 
(102) and including a code rule (22) indicating when the identified part should be used at the 
location corresponding to the associated position, the computer program being stored on a storage 
medium and comprising: 

a program module extracting unique code rules from the BOM (100); 

a program module evaluating each unique code rule in accordance with the design 
options for each order; 

a program module mapping the evaluations of the unique code rules to the 
corresponding code mles (22) in the position variant defmitions (16) in the BOM (100); and 

a program module determining the appropriate position variant (1 6) to select for 
each position (12) in accordance v^nth the mapped code rule evaluations. 



at least one cade rule element (124) corresponding to a selectable design option (126) and^ 
orders (156) are c^^ned in an order matrix (120) which cross references each puler (1560 
against the code rule eiemfe^ts (124). 

J 9. The computer prcrgmn of claim 38, whereiruh^rogram module evaluating 
each unique code rule funher comprises: 

a program module dividing each tH^ple code rule into its discrete code rule 
elements (124); 

X X 

a program module Imking ^git discrete code ^He element (124) with order data 
for the corresponding code rule elemrartl24) in the order matrix (f2St); and 

a program module^aiuating each unique code rule in accord^ce with the order 
data linked to the associated^iscrete code rule elements (124). 
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\ 40. The computer program of claim 39, wherein the program module dividing 
each unique^de rule comprises: 

a\program module factoring each unique code rule into simple/^ code rule 
components ( 1 24);\nd ^ / 

a program module dividing the code rule components into discrete code rule 
elements; and \ / 

the program module evaluating each unique code rule further comprising: 

a program nwdule evaluating each code rule component in accordance wth 
the order data linked to the associated discrete code rule elements (124); and 

a program module evaluating each unique^code rule in accordance vtith the 
evaluated code mle components. \ ^ / 

4 1 , The computer program of claim 3^, wherein each position variant ( 1 6) has 
an associated validity period and the program module extracting unique code rules comprises a 
program module for extracting unique code rule^^Iy from those position variants (16) which 
have not expired at a specified start time in aarordance with the validity period. 

42. The computer pro-am of claim 4 1 ,Vherein a sequence of orders ( 1 56) in 
the order matrix (120) indicates a unfe sequence of manuikcture of said orders, the program 
fiirther comprising: / \ 

a program modul/determining, in accordance witkthe specified start time, a build 
time when the article of manu&cture associated with each particular order will be manufactured; 
and / \ 

the mapptog program module comprises a module mappmg the evaluations of the 
unique code rules to me conesponding code ndes (22) in the position variant definitions (16) only 
for those particulm- orders (154) which have a build time within the v^idity period of the 
respective posinon variant. \ 

/ 43. The computer program of claim 4 1 , fiather comprising a prtsram module 
repe^g the mapping step upon receipt of a resequenced order matrix to detcrrmne revised 
mMmfacmring parts requirements in accordance with the resequenced order matrix. \ 
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' ^ computer program for generating documentation for an article of 

manufacture having plural structural design variants, the computer program being stored in a 
storage medium and comprising: 

a program module defining a plurality of positions (12) each corresponding to a 
different predefined location on the article of manufacture: 

a program module assigning at least one variant ( 1 6) to each position, each variant 
(16) identifying a specific pan (102) that may be used at the location corresponding to the 
respective position (12) in accordance wth a particular design variant, so that, in a particular 
article of manufacture, only one of the at least one position variants (16) can be selected for the 
respective position (12); 

' a program module assigning component documentation data to at least particular 
ones of the position variants (16); 

a program module defining at least one assembly to be documented, each assembly 
comprising a plurality of positions (12) and having a plurality of design variants (1 6); 

a program module which, upon receipt of a customer order (154) specifying 
selected design variants: 

detemunes the specific assembly design variant defined by the customer 

order, 

aggregates the documentation data assigned to the positions in the 

assembly, and 

stores the aggregated documentation data. 

^SA^.^The comput e r progr a m of claim 44, fuilliei c o mprising a^rogxamrjm ^Me 

assigning connection documajtaaood^t^ links (14) benygen^>dSofp^^ (12); and 

the program module for a§g^2fing^fi$rthCT comprising a program module for 
aggregating documentationdata^a^signed to links (14) betweexTp^^ the assembly. 
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METHOD^!) SYSTEMFOR RESOURCE REQUIREME NT PLANMNa 

axd^nt:raitv ^ 

USING^AOIT^^ DATA MODEL 



RELATED APPLICATTOXS 

The present application claims priority from U.S. Provisional Application Serial 
No. 60/098,788 entitled "Method and System for Resource Requirement Planning for 
Generating a Production Schedule Using a Uniform Data Model", filed on September 1 , 1998. 
the contents of which are incorporated herein by reference . 

FIELD OF THE IN\nENTTON 

This invention is related to a system and method for managing resource, 
assembly, and documentation requirements for manufacture of an article of manufacnire v^hich 
has a large number of design or component variations. 

BACKGROUND OF THE CSrvnENTION : 

Products which are made of many different parts and subassemblies, such as 
automobiles, trucks, boats, airplanes, etc. are typically built and assembled in a factory using 
mass-production assembly techniques. In order to produce a large volume of items, the amount 
of each type of part which is required for each item must be determined. When only one 
product design is permitted, the material production requirements can be determined simply by 
multiplying the requirements for one item by the number of items to be produced. However, 
when the product to be produced is available in a variety of designs, each of which has different 
parts, determining the production requirements for a set of product orders becomes more 
difficult. This is particularly true for products, such as automobiles, which have a large 
number of parts, are produced in high volumes, and are often marketed with a large variety of 
different features and options that must be installed at the factory, such as engine type, 
transmission, and the like. 



SUBSTITUTE SHEET (RULE 2B) 



wo 00/1 31 1 5 PCT/EP99/06389 

2 

A manufacruring resource planning ("MRP") system is used lo process and track 
information related to manufacturing, marketing, costs, part and spare part requirements, and 
other aspects of the production, sale, and maintenance of an article. In a conventional MRP 
system of the t\'pe used in the mass production of automobiles, the pans requirements of a 
standard version of the product are detailed in a list or table called a bill of materials (*'BOM"). 
To introduce each new design variation (e.g. an automatic transmission instead of a standard 
transmission), an auxiliary BOM is generated which details the parts which must be added to 
the standard BOM to produce the variation, as well as the parts which must be removed from 
the standard BOM. Because design variations selected in combination may affect the parts 
requirements in ways which differ from inclusion of the variations separately, additional 
auxiliar}' BOMs are also often required to adjust the original and adjusted pan requirements. 

To calculate the manufacmring parts requirements for a car produced with the 
new option, the pans requirements specified in the standard BOM and one or more auxiliary 
BOMs are combined using an add-subtract process wherein the pans detailed in the appropriate 
auxiliary^ BOMs are added to and subtracted from the part requirements detailed in the standard 
BOM. Logical rules which can be evaluated in- accordance with customer order options are 
defined and are used to select which of the many auxiliary BOMs should be combined with the 
primar)' BOM for a particular customer order. While effective for designs with a small number 
of options, when more than a small number of design variations are available, the various 
BOMs and associated documentation quickly become very complex and difficult to process. 

In an alternative representation, every part used in all of the defmed variants is 
included in a single BOM. Each pan has an associated construction code rule which indicates 
when the pan should be included. The construction code rules for all valid design variations 
are typically defined at the same time. The code rules which are entered can be very 
complicated because they must be defmed in such a way that code rules for alternate variations 
do not "overlap" each other or have other logical ambiguities or inconsistencies. 

The difficulty of defining code rules is further complicated when new design 
variants are added after the initial design is defmed because a given code rule for one particular 
variation can be dependent on which other variations are permitted. In addition to defining a 
new code rule when a new design variation is added, one or more other, previously generated 
rules may also need to be updated. This can be a complex and error-prone task because 
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conventional systems do not provide an easy mechanism to identify which code ruies may be 
affected. 

In addition to defining one or more BOMs. extensive design documentation must 
be prepared. Documentation is necessary both for making decisions about the cost, production 
and delivery time, capacity restrictions, connecting processes, etc. which result from including 
a variant in the customized product, and also to ensure that information about all the parts used 
in each product produced is available for historic analysis -- i.e., for recalls, analysis in the 
event of product failure, etc. Conventional systems document each module or subassembly 
variant from the '"top-down", wherein all possible combinations of variants are separately 
documented. For example, a car design may include a seat assembly which can have one of 
three t\'pes of material (e.g., cloth, leather, vinyl), two adjustment mechanisms (manual or 
power), and two heat options (none, or heated seat). There are therefore 3*2*2 = 12 possible 
combinations of seai assemblies. In the conventional top-down design method, each of the 
twelve seat assembly variants is documented separately. 

It is apparent that as the number of design variants increases, the amount of 
documentation required increases exponentially. When product assemblies have a large number 
of options, it becomes practically impossible to document every variant. In a particular truck 
design, for example, the toul number of possible wiring harness configurations (which depends 
on a large number of factors, including not only the electronic components used, but also the 
relative position of the components) can be on the order of 2^^ (about 10^^. Because it is 
practically impossible to document every design variation, a manufacturer must predict which 
design variations or combinations of options are likely to be the most popular with customers, 
document only those variations, and then prevent the customer from ordering other non- 
documented option combinations. This prediction can be both under inclusive, omitting options 
which may be popular with customers, and over inclusive, including options which are at best, 
only infrequently ordered. 

In addition to the difficulties associated with defining code rules and documenting 
numerous design variations, a further drawback to conventional MRP systems is the time 
required to analyze customer orders and to generate information about what parts are required 
to manufacture the set of orders, when they are needed, and where the parts must be on the 
assembly line. Conventional systems determine part totals by evaluating, for each customer 
order, every code rule in the BOM. When a "hit" occurs (i.e., an evaluated code rule is true 
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and thus the part will be used), a data item is wrinen to an output record in a con^puter data 
file. This process is repeated for ever\' customer order being considered. 

A typical BOM for a luxury automobile can include 70.000 separate part/rule 
entries. Each pan entr}' has an associated code rule which must be evaluated to determine 
whether the part should be included in a given build according to the selected customer options. 
In a typical example, about 4000 particular rules are likely to be true for a given customer order 
and processing a single order may take up to several minutes. Thus, for a production run of 
8000 cars, it is not unusual for the MRP process to take a considerable amount of time to 
process and to result in a pans requirement file on the order of 10 gigabytes in size, which file 
does not include process information. Even if the MRP system utilizes parallel processing to 
evaluate multiple customer orders simultaneously, the process can still take several hours to 
complete. Because of the file size and duration of the process, conventional MRP systems are 
operated as batch routines. In addition, the long time needed for the analysis prevents 
production line managers and others from making rapid changes in the sequence customer 
orders are filled, because the effect of those changes cannot be calculated quickly enough. 

Since many factories now operate on the "just-in-time" and "real-time" 
principles, where pans required for production are delivered to the factory shortly before or 
as they are needed, the slowness of current MRP systems can have a significant impact on a 
factory's profitability. If the production line cannot respond quickly to temporary shortages in 
parts or delayed deliveries, the resultant slow-downs or shut-down of the production line can 
directly affect the profitability of the factory. 

Accordingly, it is an object of the invention to provide a process for defining and 
managing the pan, pan variant, pan connection, and part connection variant details related to 
the manufacture of an article in a simple and compact manner. 

It is a further object of the invention to provide a process for use in preparing 
a BOM which fully describes the pan requirements for all variants of a given product design 
while avoiding the exponential growth of auxiliary BOMs and variant documentation as new 
design variants are introduced. 

Another object of the invention is to provide a method and system for more 
quickly evaluating the code rules in a BOM to determine the manufacturing parts requirements 
and other information in accordance with one or more customer orders. 
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Yet a further object of the invention is to provide a resource and requirement 
planning system and method in which process and activity data relating to the physical and/or 
functional connections between parts can be tracked. 



SUMMARY OF THE INVENTION : 

When an anicle is manufactured, every part, of necessity, occupies a unique 
physical location in the anicle. When plural design variations exist, the specific part used in 
a given location can depend on the particular variation being built. According to one aspect of 
the invention, the design of an article of manufacture with a large number of variations, such 
as an automobile, is represented as a tree or net of positions which, in the aggregate, represents 
the structure of all possible variants of the anicle. Each position corresponds to a pan location 
in an actual anicle and has one or more associated variants which define the possible pans that 
can be placed in the corresponding pan location w^hen a particular article is acmally built. The 
specific pan used depends on the design variation being assembled. Each variant in the net is 
assigned a code rule which can be evaluated according to selected design options to identify the 
appropriate variant for each position and thereby the pan which should be used at the associated 
pan location in a specified design variation. Connections between parts can be similarly 
represented and identified. Code rules are defined and evaluated to ensure that at most one 
variant is selected for each position because no matter how many design variations there are for 
a given anicle, in any particular article, only one part can actually be used in each location. 
In other words, the variants associated with any given position are in an exclusive-or 
relationship to each other. 

In addition, every part in a given article is connected to at least one other part 
in some manner. In a further embodiment of the invention, these connections can be 
represented in the net as links between positions, or alternatively, as connection positions. 
Process information describing the type or method of connection between two parts, such as 
a weld or friction fit, can be associated with the corresponding position links or connection 
positions. If different kinds of connections between parts are possible, such as may result when 
different part variants are available, appropriate process variants can be associated with a link 
and assigned corresponding code rules in a manner similar to variants associated with a given 
position. In addition, if a particular part must be processed in some manner before mstailation, 
for example, by applying oil or grease, such process information can be associated with the 
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variant identifying the part. Additional data which can be associated with a connection variant 
include data which is used to group various positions into subassemblies, to associate part 
groups with panicular suppliers, etc. Further data related to production, process, and 
fabrication of the article may also be added to the position variants and/or links to fully 
document all aspects of the design across the entire life cycle of the various parts and 
assemblies used. 

According to a further aspect of the invention, the net representation can be 
translated into a BOM suitable for use in an MRP process. In addition to listing each part 
variant and its associated code rules, as is done in conventional systems, the BOM also 
associates each variant with a specific position corresponding to, e.g. , a physical location in the 
anicie. This additional information permits all variants of a given position to be quickly 
determined. Advantageously, long code rules for each variant need not be used, but instead 
shoner. easier to understand rules may be used, even if those rules are not logically complete 
and overlap to some extent. At predetermined times, such as after a new variant is defined, all 
rules from variants associated with the affected position can be automatically identified, 
analyzed, and updated as needed to be logically consistent, minimize overlap, and to properly 
take into account the effect of other variants. 

According to a further aspect of the invention, an improved method and system 
for calculating manufacturing parts requirements on the basis of customer orders is presented. 
Prior to evaluating the code rules in a BOM, each unique code rule is extracted from the BOM, 
assigned a unique rule ID, and placed in a code rule matrix. Each code rule in the code rule 
matrix is then evaluated only once, and in parallel, for all customer orders to be analyzed and 
the results stored in an evaluated code rule data matrix. The evaluated code rule data is then 
mapped back to each code rule entry in the BOM, 

Because only one bit per unique rule per order is needed to store die results of 
the unique code rule evaluations, the resulting data matrix is very small when compared to the 
output file of a conventional MRP system and can be stored entirely in RAM (random access 
memory). Advantageously, because each unique code rule is only evaluated once, regardless 
of the number of times it appears in die BOM, and because the number of unique code rules 
is generally substantially less than the total number of entries in the BOM, a significant decrease 
in processing time is achieved. Processing can be further optimized by simplifying and 
factoring the code rules prior to evaluation. 
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(random access memory). Advantageously, because each unique code rule is only 
evaluated once, regardless of the number of times it appears in the BOM, and because the 
number of unique code rules is generally substantially less than the total number of entries 
in the BOM, a significant decrease in processing time is achieved. Processing can be 

5 further optimized by simplifying and factoring the code rules prior to evaluation. 

Using a system which includes various features of the invention, an article 
of manufacture can be manufactured by initially defining a plurality of positions 
corresponding to different, predefined physical locations in the article. One or more 
variants are assigned to each position, where each variant corresponds to a particular part 

10 or assembly which can be placed in the location associated with the position. For any 
given manufactured unit, only one part can be placed in a given physical location and so 
only one variant can be selected for each position. Each variant therefore has an 
associated manufacturing code rule which indicates when the particular variant should be 
used in accordance with specified design options . 

15 When a particular ordered product is to be manufactured, the code rules are 

evaluated to identify the proper variant to select for each position and thus the specific 
parts needed to build the ordered product. This information is then used to ensure that 
the necessary parts are available and are delivered to the correct assembly line stations. 
The ordered product is then manufacmred using the identified parts. 

20 Advantageously the system and method of the iuvention permit savings in 

a variety of costs, including costs related to materials, diagnostics, delivery, production 
planning and recalculation, product re-engineering, personnel, and recycling. 

BRIEF DESCRIPTION OF THE DRAWINGS : 
25 The foregoing and other aspects and advantages of the invention will be 

better understood from the following detailed description of preferred embodiments of 
various aspects of the invention with reference to the drawings in which: 

Figs. 1-5 are graphical representations of a position/variant data net for 
representing an article of manufacture and design variants; 
30 Fig. 6 illustrates various sub-assemblies and assembly groupings in a 

position/variant net; 

Fig. 7 illustrates a hierarchical net related to the net of Fig. 6; 
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Fig. 8a illustrates a net containing group definition data for the groupings 

of Fig. 6; 

Fig. 8b is an illustration of a net containing group definitions as in Figs. 
6 and 8a and a hierarchical structure as in Fig. 7; 
5 Fig. 9 is a representation of a number of positions and variants relative to 

an assembly line; 

Fig 10 is an example of a CAD representation of one variant of a side panel 

for a car; 

Fig. 11 illustrates a linking between a position in a net and a part 
10 description in a CAD system; 

Fig. 12 is a table illustrating a portion of a bill of materials (BOM) for a 
given car design; 

Fig. 13 is a sample customer order matrix; 

Fig. 14 is a flow diagram of a method for generating an order matrix; 
15 Fig. 15 is a flow diagram of a method for evaluating the code rules in a BOM; 

Fig. 16 is a diagram illustrating the creation of a code rule matrix from a 

BOM; 

Fig. 17 shows a sample evaluated rule matrix; 

Fig. 18 is an illustration of a manufacturing resource planning (MRP) 
20 matrix for the BOM of Fig. 16 and the evaluated rule matrix of Fig. 17; 

Fig. 19 shows a sample material resource plannmg matrix; 

Fig. 20 illustrates various applications of MRP data; 

Figs. 21 and 22 are flow diagrams of a particular method of evaluating the 
code rules in the code rule matrix; 
25 Fig. 23 is a sample code rule matrix; 

Figs. 24-25 are mtermediate code rule evaluation matrixes; 

Fig. 26 illustrates linking of data between an intermediate rule evaluation 
matrix and the order matrix; and 

Fig. 27 is an illustration of an evaluated rule matrix in accordance with the 
30 intermediate matrix shown in Fig, 26. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS: 
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FIGS. 1-5 are graphical representations of a uniform product model or net 10 
which represents an article of manufacture having a number of design variants and which can 
be used to analyze the anicle for the purposes of determining parts requirements, manufacturing 
data, etc. For simplicity in the following discussion, the anicle of manufacmre will be 
considered to be a car. However, this is not intended to be limiting and the invention can be 
applied to other articles of manufacmre. In addition, the invention will be discussed primarily 
with regard to variations in the parts used to manufacmre a given article. However, as detailed 
further below, variations in connections between parts can be treated in a similar manner. 
Accordingly, while the term "part" is used throughout, one of skill in the an will appreciate that 
various feamres of the invention can also be adapted to represent and process connection 
requirements. 

Net 10 has a plurality of positions 12 connected by links 14. Each position has 
a unique position ID that can be mapped to an acmal physical location in a manufacmred 
product. At each position 12, one or more position variants 16 are defined. (Fig. 2) Each 
variant 16 identifies a specific part which can be placed in the article at the location 
corresponding to the position associated with the position variant. The acmal part used is 
dependent on the specific design variation to be built. Thus, the position variants for a given 
position represent all the possible parts which can be placed in a given physical location in a 
manufacmred article. The collection of variants for all positions collectively describe every 
potential design variation of the article. 

In the net 10 shown in Fig. 2, position 12 includes three position variants 16a, 
16b, and 16c. The specific position variant which should be selected for a given manufacmring 
order is dependent on the design options selected by, e.g. , the customer. For example, position 
variants I6a-16c may indicate that the specified position, and ultunately , the associated location 
in the article, can contain either a 4-, 6-, or 8-cylinder engine, respectively. Fig. 3 is an 
illustration of three nets 10a, 10b, and iOc, which correspond to the three product variants that 
are defmed by the net 10 of Fig. 2, Fig. 4 illustrates various nets with position variants and 
connecting links of various complexities. 

To reflect the fact that at most one position variant 1 6 can be selected for a given 
position 12, each position variant has an associated code rule that indicates when the specific 
position variant should be selected. Code rules can be assigned as position variants are placed 
in the net and will be described in more detail below. In addition to identifying a specified part 
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(i.e. , by referencing a pan number in a master pan database) and having an associated code rule 
which indicates when the pan should be used, position variants can also have additional 
associated data which indicates, for example, a time period during which the particular position 
variant (and associated code rule) is valid, the assembly line station where the pan must be 
present during product manufacturing, the estimated duration of time needed to install the pan, 
preprocessing (e.g. , oiling or greasing) which must be done to the pan prior to installation, etc. 

Advantageously, the position and position variant representation of the product 
design illustrated in net 10 can be mapped directly to a bill of materials ("BOM") for use in an 
automotive manufacmring resource planning ("MRP") system. In addition, the position can be 
used as a reference to link the BOM (or net) representation to other design representations, such 
as parts or connections defined in a CAD system. These aspects of the invention are discussed 
in more detail below. 

Links 14 between the positions 12 indicate connections between pans. In some 
instances, particularly when two connected positions each have associated variants, the type of 
connection between parts may vary. With reference to Fig. 5, position 12a, with position 
variants PAl, PA2, is connected to position 12b. with position variants PBl, PB2. Depending 
on the position variant selected, the type of physical connection between the parts installed at 
the locations corresponding to positions 12a and 12b can differ. For example, parts PAl and 
PBl must be joined with bolts while parts PAZ and PB2 must be joined to each other by clips. 

This difference in connection type can be represented by defining a new unique 
connection position 12c between position 12a and 12b and having variants which indicate the 
type of physical connection required. The code rules associated with each of the variants at 
positions 12a, 12b, and connection position 12c are defined such that the proper connection 
variants are selected. In the example of Fig. 5, one code rule can be assigned to the first 
variant ui each position 12a, 12b, and 12c and a second code rule assigned to the second variant 
of these positions. When the first code rule is true (and the second false), the net indicates that 
pans PAl and PBl are connected by PCI. When the second code rule is true and the first 
false, the net indicates that parts PA2 and PB2 are connected by PC2. Of course, the code rules 
for the connection position 12c need not be the same as that of the connected positions 12a, 
12b. For example, if parts PAl and PBl can be joined to each other either by welding or by 
clips, the code rules for the variants at position 12c can be defined to allow either of these 
design variations to be selected in accordance with a particular product order. 
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Other types of information may also be assigned to the links and possibly the 
position variants. Such information includes data related to product assembly and production 
planning, t\'pes of assembly equipment required, pan availability dates, product documentation, 
pan and connection failure data. etc. While similar types of information have been generated 
for use in and by conventional manufacturing and assembly plants, such information has 
previously been separately maintained. Advantageously, by use of the present invention, all 
such information can be integrated into a single production data model. 

It can be appreciated that a position can be defined for every connector which 
is used to join two or more pans to each other. However, a connection often is made with 
multiple duplicate pans, i.e., two pans may be fastened to each other with eight bolts. To 
simplify the representation of multiple identical pans which are essentially used at the same 
location in an anicle, a pan multiplier indicating how many of a given pan (or connection) are 
used can be associated with the position variant and referenced when calculating pans 
requirements. 

It is possible, if desired, to group positions into sub-assemblies and sub- 
assemblies into assemblies in order to visualize how the various pans in a design fit together 
and to create assembly hierarchies. In addition, components are often combined into separate 
assemblies which are connected together at a later time. Fig. 6 is an illustration of a net 10 in 
which positions 12 have been grouped into sub-assemblies 1 , 2, and 3, and these sub-assemblies 
have been further combined into assembly 4, as indicated by the broken-lines. 

Groupings can be used to define production nets at different levels of assembly 
hierarchy. Fig. 7 is an illustration of a net 10* showing the relationship between sub-assemblies 
1, 2, and 3 at a hierarchical level above the base net 10 of Fig. 6. As shown in Fig. 6, sub- 
assembly 1 includes position 12a with two defined position variants and position 12b with three 
defined position variants. Thus, there are a total of 2*3 = 6 design variations of sub-assembly 
1 in Fig. 7, which variations encompass the variants of the individual positions within the sub- 
assembly. These are shown as position 12c. It can be appreciated that as the hierarchical level 
of the net increases, the number of potential variants for each position also increases 
dramatically. 

One method of representing pan groupings is by assigning a particular group 
number to each link 14 between the positions 12 in the group. Fig. 8a is an illustration of such 
a group definition that corresponds to the graphical grouping shown in Fig. 6, As shown in 
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Fig. 8a, a group number 18 (e.g.. "2") is assigned to each link 14 connecting the positions 12 
in the group. Groupings, such as illustrated in Figs. 6-8, can represent physical groupings for 
produced sub-assemblies and can be used to define nets 10 at different hierarchical levels of 
representation, such as net 10' shown in Fig. 7. Fig. 8b is a more complete illustration of a 
net 10 which illustrates the grouping concepts shown in Fig. 6 and 8a and the hierarchical 
strucmre of Fig. 7. 

In addition, other, perhaps overlapping, groupings can be defined to represent 
functional groups (e.g., all positions in the electrical system), or other useful sets of 
information, such as pans which must be painted. These groupings define hierarchical "view 
points" from which aggregate information about the included parts can be generated. A 
viewpoint is distinct from a position in that a position can be mapped to a physical location in 
the product which contains at most one pan (or sub-assembly) while a viewpoint can have 
attributes which represent various aggregations of information related to grouped positions and 
position variants. 

Fig. 9 is a representation of a number of positions 12, each with one or more 
position variants 16, presented as the various parts may be placed along an assembly line 20 
having assembly stations 24 which assemble pans P1-P7. Each position variant 16 is illustrated 
with an associated representative code rule 22. The actual parts which are used during 
assembly are selected according to which one of the possible position variants is appropriate 
for a given order. The possible position variants for each particular position can be summarized 
as a combination 26 of the position variant code rules 22. 

For example, at line position P3, one of three position variants can be selected 
according to the evaluation of code rules S, CI , and C2. The combination of the code rules for 
the three variants are summarized as SeCl©C2, where indicates an XOR (exclusive-or) 
function. The XOR operator is used because only one position variant 16 may be properly 
selected for the position 12, and thus only one of the three code rules 22 is properly true for 
a given order. 

The parts PI, P2, and P3 can be grouped into a sub-assembly A which has 6 
variants, of which only one can be selected. Box 25 A details the 6 possible variants of 
subassembly A, where " [ " indicates the combining of parts (as represented here by the code 
rule assigned to the position variant defining the part). The six possible subassembly variants 
can be written in shorthand as a combination of the summarized code rules. Thus, the set of 
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possible subassemblies A can be designated as "SjSeCS lSeCleC2" (Ref. 27A). Similarly 
parts P5, P6, and P7 can be grouped into a sub-assembly B which also has 6 variants, detailed 
in box 25B and summarized as "S 1 SeB3 ] SeBleB2" (Ref. 27B). Sub-assemblies A and B and 
part P4 can be further grouped into an assembly D. which has 36 variants, summarized as 
"S|S©C3lSeCl©C21SlS|SeB3|SeBleB2" (Ref. 27D). A portion of the 36 design variations 
for assembly D are detailed in Box 25D. 

The subassembly and assemblies A, B, D, can be mapped directly to a net 10. 
such as previously illustrated. In addition, the positions which make up sub-assemblies A, B. 
and D can be grouped together to define viewpoints with various functions assigned to them 
which are evaluated once the specific design variants have been chosen. For example, a 
viewpoint A' (not shown) can be defined to be the weight of the selected position variants 
making up sub-assembly A, the aggregate cost of the sub-assembly, the time to assemble, the 
position on the assembly line where the sub-assembly is completed, etc. 

In addition to detailing design variations, e.g., via net 10. it is also necessar>' to 
provide separate documentation for assembly and sub-assembly variants which are 
manufactured. Such documentation is used in making marketing decisions about various 
options and also to ensure that information about all the parts used in each product produced 
is available for historical analysis associated with actions such as product recalls. 

In a conventional system, documentation is generated using a "top-down" 
approach, starting from the assemblies at the "top" of the hierarchy (e.g., assembly D of Fig. 
9) and then moving to smaller sub-assemblies. However, as illustrated, the total number of 
design variations increases dramatically as more positions and position variants are included in 
the assembly definition. In a conventional approach, all thirty-six variants of assembly D in 
Fig. 9 would be separately documented or, alternatively, the number of permissible variants 
would be limited. 

In contrast, and according to an aspect of the invention, documentation for 
assemblies, etc., is generated from the bottom up. In this way, documentation is created for 
the actual assemblies made, instead of creating documentation for all possible assemblies, 
regardless of whether they are in fact made or not. In panicular, the information necessary to 
prepare the documentation for a given assembly is distributed among all of the included variants 
for each position as the variants are defined. Each specific variant has associated data which 
represents the information to include in an assembly documentation for assemblies that include 
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the variant. When a particular order is filled, the specific variation of the assembly to be 
produced will be known since a position variant will have been selected for each position. Once 
the individual variants are known, a check is performed to determine whether the resulting 
assembly has been previously documented, e.g., as may occur if a prior order resulted in 
manufacmre of the same assembly variation. If the assembly has not been documented, the 
documentation information associated with each selected position variant is combined to create 
the historical documentation needed for the assembly. Thus, assembly documentation is created 
as needed, using a bottom-up approach, in a manner which permits a large number of possible 
assembly variants to be available for manufacmre while also ensuring that each manufacmred 
assembly variation is properly documented. 

For example. In Fig. 9, the specific position variant selected for each position 
12 is indicated by an "x'' . These selections indicate that the fifth variation of sub-assembly A, 
"S|C3 iCl". has been selected and the third variation of subassembly B, "S |S 1B2" has been 
selected. The combination identifies the specific one of the 36 possible variations of assembly 
D which will be built (e.g. , "S | C3 | CI | S | S | S | B2"). The documentation associated with each 
position variant can be combined to produce documentation for the specific variant selected. 

As previously noted, positions 12 in net 10 can be used as a key to link the net 
representation of a product with a representation in a computer aided design ("CAD*') system. 
In a CAD system, parts are generally represented as a collection of various part attributes, such 
as surface contours, bends, projections, etc. Fig. 10 is an example of a CAD representation 
of one variant of a side panel for a car. As shown, a single component 28 may have a very 
large number of CAD design elements 29. These elements 29 can be combined into a single 
element 30 in the CAD system which represents one part or connection between parts that is 
used during car assembly. The CAD pan number or connection number can then be tied to the 
net representation 10, e.g., by including die CAD part number as an attribute of a variant 
defined for that position. This linking is graphically illustrated in Fig. 11 where the collection 
of CAD elements 29 defining CAD component 28 are all assigned to a reference label 30 which 
is then associated with a particular position variant 14 of a position 12 of net 10. 

Various methods of storing the information represented by net 10 in a computer 
system can be used, as will be apparent to one of skill in the art. For example, the various 
positions 12 can be represented using a complex or object-oriented data structure which contains 
each element definition. Alternatively, the position and position variants can be directly 
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implemented as a net of linked data nodes, each having associated data values. Other data 
strucmre arrangements known to those of skill in the art can be used as well. 

In a preferred embodiment, the information is stored in a database as a data 
matrix which can be used as a production BOM and. when combined with a set of customer 
orders, used to determine what parts are needed to produce the orders, when they are needed, 
and where on the assembly line the pans need to be delivered. This panicular implementation 
of the invention will now be discussed. 

Figs. 12a- 12b shows a table illustrating a portion of a bill of materials (BOM) 
100 for a given car design. The BOM 100 contains a large number of records (rows) 101 , each 
of which identifies a specific position 12 and position variant 16 which corresponds to the 
position and position variant information described generally above with respect to net 10. 
Each BOM record 101 also specifies a pan ID 102 and a code rule 104 (corresponding to code 
rule 22 in net 10), In the sample table of Figs. 12a-12b, the first six records all have the same 
position "10 16 04 0100" (reference No. 108) and different variant identifications (reference 
No. 110). As can be seen, each position variant in position "10 16 04 0100" has a different 
pan ID number and code rule. 

Although detailed pan information can be included in each record 101 , the pan 
ID 102 is preferably used to reference a master pans list (not shown) which contains detailed 
information about the pan, such as the manufacturer of the pan, its weight, cost, delivery time, 
etc. BOM records 101 can also contain a textual pan name 106, a model nimiber or type 105, 
as well as additional information including a time period within which the variant (and code 
rule) is valid, an assembly line position to which the pan should be delivered if needed, the 
estimated time installing the part will take, etc. (all not shown). 

As discussed above, code rules are used to determine when a given position 
variant should be included in a particular product order. Each code rule is a logical statement 
including one or more code rule elements, where each code rule element corresponds to an 
option which can be selected in a product order to be manufactured. In addition, a code rule 
can indicate whether the position variant is "standard" or default, and therefore whether it 
should be used if no other relevant options have been selected. 

Fig. 13 is a sample customer order matrix 120 which contains a plurality of build 
options 122 and associated code nile elements 124 for multiple orders of a specific car model. 
For example, code rule elements "Ml 13", "M136", "M154" and "M172" represent the type 
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of engine while code rule elements ^'494". "498". and "625" indicate the country in which the 
ordered car is to be sold. Customer order matrix 120 further contains selected option 
information for a plurality of customer orders 126, each order corresponding to a column 
indicating which build options are included in the order, and therefore also indicating whether 
each panicular code rule element is true or false for the order, A "1 " in a particular row of an 
order column indicates that the corresponding option has been selected for that order and that 
the associated code rule element is true. 

By evaluating the code rules in the BOM 100 using the data in the order matrix 
120. a determination can be made about the specific parts required to manufacmre the given 
product order. Preferably, the sequence of orders 126 in the order matrix 120 indicates the 
sequence in which the cars will be manufacmred. The time when each car will reach various 
manufacmring points can be determined based on information including the speed of the 
assembly line and possibly other factors related to the specifics of the particular order, such as 
the time required to install particular parts. (By including the time duration required to install 
particular parts within the position and position variant information in the BOM, an estimate 
of the manpower or other resources required to assemble the order can also be determined.) 
By using knowledge about what parts are required and when they are required for a given 
order, as well as the position the part corresponds to, the necessary parts can be routed to the 
correct assembly line stations as they are needed, allowing the number of parts stored at each 
station to be minimized. 

As mentioned above, each position variant entry in the BOM contains a code rule 
which indicates when the designated pan should be used when a given customer order is built. 
As can be appreciated, certain parts used in the car, such as an element in the exhaust system, 
may be dependent on more than one option. For example, the part selected may depend on 
both the engine type selected and the particular country in which the car is to be sold (e.g., as 
a result of various legal requirements). Such position variants can be represented in a BOM 
using shorthand or short" code rules as follows: 

POS POSV PART NO. SHORT CODE RULE 

1000 001 PI Ml 13; (SRI) 

1000 002 P2 M113*494; (SR2) 

1000 003 P3 Ml 13 • (496 + 625); (SR3) 
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where indicates a logical AND and " + " indicates a logical OR. In position 1000, pan PI 
is used when the Turbo Diesel engine (Ml 13) is selected, part P2 is used for a Turbo Diesel 
engine in a car produced for sale in the US (494). and pan P3 is used for a Turbo Diese! engine 
car produced for sale in Japan (496) or Australia (625). Because all three pans PI . P2, and P3 
are associated with the same position (which corresponds to a physical location in the car), the 
pans are mutually exclusive options and only one can be selected for use in a given product 
order. While an individual viewing the short code rules may understand this distinction, the 
shon code rules are inadequate for logical analysis purposes, such as calculating manufacturing 
pan requirements, because code rule SRI will be true whenever code rule element M113 is 
true, even if code rules SR2 or SR3 are also true. 

To eliminate this ambiguity, the separate shon code rules can be combined such 
that each code rule contains elements which guarantee that the rule is not true when another 
variant should be used. For example, shon code rules SRI, SR2, and SR3 can be combined 
to generate long code rules LRl, LR2. and LR3, where, for example, LRl is true when SRI 
is true and both SR2 and SR3 are false. For the above example, the resulting long code rules 
may be expressed as follows: 



POS 


POSV PART NO. 


LONG CODE RULE 


1000 


001 


PI 


M113 • -(494 + 496 + 625); (LRl) 


1000 


002 


P2 


M113 • 494 • -(496 -i- 625); (LR2) 


1000 


003 


P3 


M113 • -494 • (496 + 625); (LR3) 



where tlie operator indicates a logical NOT. Although tlie resulting equations can be 
reduced to some extent, they are relatively long and cumbersome to work with. However, 
because of their accuracy, conventional MRP systems require that long code rules be used for 
each position variant which is defined. As a result, definition and entry of code rules for use 
in a conventional MRP system is a tedious and potentially error prone process. 

One of skill in the an will appreciate that long code rules are often more complex 
than necessary, especially when they apply to required and/or mutually exclusive options. 
However, they are often used in conventional systems so that errors in customer order selection 
will not produce drastically corrupted pans data. In a preferred implementation of the 
invention, customer orders are preprocessed to detect situations in which mutually exclusive 
options are selected or a required option selection has not been made in order to prevent those 



SUBSTITUTE SHEET (RULE 26) 



wo 00/131 1 5 PCT/EP99/06389 

18 

orders from being used to evaluate BOM code rules. For example, an order must have only 
one engine type selected. An order with no engine type selected or two engine type selections 
is in error and may result in erroneous data when the code rules are evaluated. By filtering out 
problem orders during preprocessing, the code rules which are implemented in the BOM 100 
do not need to be as robust as the long code rules described above, and therefore, can be 
simplified. 

For the shon code rules SRI, SR2, and SR3, above, for example, if orders are 

preprocessed to ensure that two countr>' selections have not been made, short code rules SR2 

and SR3 will never be true at the same time. Thus, it is not necessar>' to expressly guard 

against this occurrence with the more complex long code rules LR2, LR3. Instead, the only 

code rules which need to be expanded to eliminate overlap with other rules are those code rules 

which describe "supersets'' of other variations (e.g., the set of orders with engine type Mil 3 

is a superset of the set of orders with engine type Ml 13 to be sold in the United States). The 

remaining rules can be left in the simplified short code rule form, thus reducing the overall 

complexity of the defmed code rules and decreasing the time required to evaluate them. A set 

of such "complete" rules for the above example is shown below. 

POS POSV PART NO. COMPLETE CODE RULE 
1000 001 PI Ml 13 • -(494 + 496 + 625): 

1000 002 P2 M113-494; 
1000 003 P3 Ml 13 ' (496 + 625); 

It is apparent that in both the long code rule and the complete code rule 
representation, at least one of the code rules depends on the code rules which have been defined 
for other variants. A significant problem with conventional MRP systems is that the BOM 
which lists position variants and associated code rules does not associate each defmed position 
variant with a particular position corresponding to a physical location in the product. Because 
of this deficiency, it is difficult to identify all code rules which may be affected by the new 
variant. Thus, the long code rules for all variants are typically generated manually at the same 
time. In addition, as variants are defined at later points in time, e.g., a new type of steering 
wheel option is made available, several code rules may need to be updated. However, because 
the BOM in a conventional MRP system does not include the information needed to identify the 
potentially affected rules, the necessary manual revisions of code rules can be a cumbersome 
and error-prone process. 
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According to a further aspect of the invention, the inclusion of position and 
position variant information within the BOM simplifies code rule defmition by permitting 
position variants to be initially defined using shon code rules. Corresponding long or complete 
rules are automatically generated as needed. In a preferred embodiment, at predefined times, 
such as when a new position variant for a given position is added, the BOM 100 is 
automatically examined and all position variants for that position are extracted. The existing 
code rules are then analyzed and the new code rule and the previously defined code rules are 
revised as needed to account for overlaps between the code rules. 

For example, a series of short code rules can be combined to generate 
corresponding long code rules or, if orders are preprocessed to ensure validity, generate a 
corresponding set of complete code rules. Various methods for determining the overlap in 
scope between the identified code rules and adjusting the identified code rules to remove at least 
some of the determined overlap, e.g.. by applying set theory, will be apparent to one of skill 
in the an. If an ambiguity is detected and cannot be automatically resolved, it may be necessary 
to manually resolve the ambiguity or correct the new code rule as needed. The adjusted code 
rules that are generated, which may be quite complex, are then automatically included in the 
BOM 100, The short rules can also be retained in the BOM for future reference. 

A method for determining manufacturing resource data for use in various 
functions, such as invoicing, inventory control, and parts routing, will now be discussed with 
reference to the flow diagrams in Figs. 14a, 14b, 15a, and 15b. 

Turning to Figs. 14a-14b, there is shown a flow diagram of a method for 
generating an order matrix 120. As discussed above, appropriate preprocessing of customer 
orders permits the use of complete code rules to identify position variants in the BOM 100, as 
opposed to the more complex long code rules. Such preprocessing can include several steps. 
When a sales order is initially generated, it typically is not in the form of a table of code rule 
elements 124, such as in Fig, 13. Instead, raw sales orders 140 are typically in the form of 
package selections, such as a "sport" or a "luxury" package, which is made up of groups of 
build options 122, each of which has a corresponding code rule element 124. A table of 
marketing code definitions 142 is used as a reference to expand a raw sales order 140 into an 
unvalidated sales order 146, An un validated sales order 146 is similar to a customer order 126, - 
such as shown in each column of the matrix in Fig. 13, but may contain errors, such as 
selection of inconsistent options or failure to make required option selections. 
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To detect these and other errors, an unvalidated order is preferably subjected lo 
a plausibility check (step 148) and a conflict check (step 152) and a validated order 156 is 
generated. The plausibility check ensures that the selected options are available for the 
specified model and that, as of the order date, the options have been released to the public in 
the designated market in accordance with availability data 150. The conflict check, made in 
accordance with conflict data 154, ensures that all required selections have been made, that 
there are no inconsistent selections, and may also verify that the selections comply with various 
marketing package requirements. Once a validated order 156 is available, it can be added to 
the order matrix 120. 

Before the orders which are detailed in the order matrix 120 can be 
manufactured, the code rules in the BOM 100 must be evaluated to determine which position 
variants should be used at each of the defined positions, and thus which pans are required for 
each corresponding location. In conventional systems, for each order, ever>' code rule in the 
BOM is evaluated in turn to determine the manufacturing pans required to fabricate the ordered 
car. However, this process is generally inefficient and processing times of up to several 
minutes per order are not uncommon. 

Preferably, the code rules in the BOM 100 are evaluated using the order matrix 
data on a rule-by-rule basis, wherein each unique code rule in the BOM is evaluated once for 
each order. Most preferably, a first unique rule is evaluated for all of the orders in the order 
matrix before a next rule is evaluated. Then, the results are mapped back to the various code 
rule entries in the BOM. The preferred method of evaluating the BOM code rules is illustrated 
generally in Figs. 15a-15b. 

First, the entries in the BOM 100 are analyzed to identify each unique code rule 
statement which is used anywhere in the BOM 100 (step 160) and a code rule matrix 162 which 
contains these unique code rules is generated. The code rule statements in the code rule matrix 
162 are each assigned a code rule ID 163, which can simply be the record or row number in 
the code nile matrix 162. For simplifying later reference, the code rule IDs 163 are mapped 
back to the individual code rule statements 104 ui the BOM 100. Advantageously, while there 
can be a very large number of entries in the BOM, the number of unique code rules is generally 
only a small fraction of that total. 

Preferably, the BOM 100 is stored as a table in a generalized database program 
and the unique code rules are extracted by sorting the rows in the BOM 100 with the code rules 
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as a primary key and then using standard database functions to create a table which contains 
each distinct code rule entry only once. The specific functions required to extract the rules in 
this manner depend on the database being used and will be known to those of skill in the an. 

Fig. 16 illustrates a portion of a sample BOM 100' which contains eight position 
variants distributed across three positions. Each position variant has an associated code rule, 
e.g., CRl. As shown, the same code rule may be associated with more than one position 
variant. For example, position 1000, variant 1 and position 1001, variant 1 utilize code rule 
"CRl". The initial code rule matrix 162 derived from this BOM 100' contains only five 
entries, one for each unique code rule. In this example, the unique code rule ID 163 is simply 
the record number in the code rule matrix 162. The code rule IDs 163 are added to the BOM 
100' as shown. Although in this example, a separate code rule ID column has been added to 
the BOM 100'. the code rule ID does not need to be expressly recited in the BOM and other 
techniques to associate each code rule usage in the BOM with its corresponding entry in the 
code rule matrix 162. such as relational links, can be used instead. 

Those of skill in the art will appreciate that different position variants may be 
valid at a given position during different periods of time. For example, a pan may be 
discontinued or not available until a designated time period. Accordingly, each position variant 
code rule in the BOM 100 can have an associated validity period, generally in the form of a 
from-date and a to-date, the values of which indicate when the rule is valid (i,e. , the variant can 
be selected) and when the rule is invalid (i.e., the variant cannot be selected). In a preferred 
embodiment, as the unique code rules are extracted, those code rules which have expired are 
filtered out and are not added to the code rule matrix 162. These rules may be retained in the 
BOM, however, and assigned a distinct rule ID which indicates that the variant is expired and 
the code rule need not be evaluated. The resulting code rule matrix 162 will thus contain only 
non-expired rules, i.e., those which are presently valid or will become so at some time in the 
future. 

Once the code rule matrix 162 has been generated, each unique rule in the matrix 
162 is then evaluated using the option data detailed in the order matrix 120 (Figs. 15a-15b, step 
164) to thereby generate an evaluated rule matrix 166 (see Fig. 17). There are a variety of 
methods by which the individual code rules in the code rule matrix can be evaluated. In contrast 
with the conventional method of evaluating all rules applicable to a specific customer order 
before moving on to the next customer order, preferably, each unique code rule is evaluated 
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once in the order matrix 120 and the results stored in the evaluated rule matrix 166 before the 
next rule is evaluated. By evaluating a code rule once for all customer orders (regardless of 
how may times the code rule appears in the BOM) before evaluating a next code rule, extraction 
of data from the order matrix can be optimized, increasing the speed of code rule evaluation. 
A most preferred method of evaluating code rules in the code rule matrix is discussed in more 
detail below with reference to Figs. 21a, 21b, 22-24. 25a, 25b, and 26-27, 

The evaluation of each unique code rule for a given order can be represented as 
a single bit within a bit matrix 167 that is included within the evaluated rule matrix 166. The 
rule evaluation data stored in the matrix 167 is in a very compact form, requiring for m unique 
code rules and n orders, only m'^'n bits, i.e., only one bit per rule per order. An illustration 
of a sample evaluated rule matrix 166 containing bit matrix 167 is shown in Fig. 17. 

A typical BOM for a luxury automobile can include 70.000 separate part/rule 
entries, but only about 4000 unique code rules. Advantageously, evaluating the code rule 
matrix 162 for an order matrix having 8000 orders results in a bit matrix 167 which is 
approximately 32 million bits in size, or approximately 3.8 megabytes. This amount of 
information may easily be contained within the RAM of a conventional personal computer or 
workstation, eliminating the need and associated delays of writing intermediate or partial results 
to disk. 

Finally, the evaluated rule data 167 contained in the evaluated rule matrix 166 
is mapped to the individual code rule statements in the BOM 100 to generate an MRP matrix 
170 which indicates for each position defined in the BOM 100, which variant 16 has been 
selected for each order (Figs. 15a-15b, step 168) and, preferably, how many of each part is 
required for the selected position variant. In most cases, only a single pan will be needed and 
thus a hit (designated as "1 ") also indicates that one of the identified position variant is required 
for the given order in the specified position. However, especially when connector parts are at 
issue, a single variant may, in fact, represent several parts, such as bolts, screws, clips, etc. 
While each part could be separately defmed in its own position, to simplify the definition of 
multiple parts, a part multiplier indicating how many of a part identified by a position variant 
is used in the associated location can be included as part of the position variant entry and this 
multiplier later used to determine the true number of parts required. 

Fig. 18 is an illustration of such an MRP matrix 170 for the sample BOM 100' 
shown in Fig. 16 and the evaluated rule matrix 166 shown in Fig. 17, A more complete sample 
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of an MRP matrix 170 is illustrated in Figs. 19a- 19b. Turning to Fig. 18. the portion 171 of 
the MRP matrix 170 contains the rule evaluation data for each code rule taken from the 
evaluated rule matrix 166. e.g., as linked by the code rule ID. As illustrated, for each order 
l,..n. only one of the possible position variants 16 is selected at each position. For example, 
order 1 requires part Al (variant 01) to be used in the location associated with position 1000 
while order 2 requires pan A3 to be used in that location. By adding up the parts requirements 
for the desired number of orders, the total number of parts required to manufacmre the ordered 
cars can be easily and quickly determined. 

In Fig. 18, the position variants associated with position 1002 each have a 
multiplier of eight associated with them. Thus, in order 1, eight C3 parts are used in the 
location corresponding to position 1002, in order 2, eight C2 pans are used, and, in order 3, 
eight CI parts are used. In this example, the multiplier has been applied to each order. 
Alternatively, application of the position variant multiplier can be deferred until the total 
number of parts for a given position/ variant is determined. In such a situation, the hits for 
variants having a muhiplier greater than 1 can still be represented as "V in the BOM. When 
the part totals are determined, the sum for each variant is then multiplied by the multiplier to 
determine the actual number of parts required. Although deferring use of the multiplier in this 
manner increases processing speed, it may cause additional complications since summations of 
the raw MRP data would no longer directly represent the total parts requirements. 

As discussed above, position variants may have an associated time period within 
which they are valid. Code rules for expired variants can be filtered out when the code rule 
matrix 160 is built. However, it is possible that presently valid variants may become invalid 
during the manufacturing time span covered by the orders in the order matrix 120, while other 
variants which are not yet valid at the start of manufacturing become valid before all of the 
orders defined in the order matrix 120 have been manufactured. Given a time and date when 
manufacmring of the customer orders in the order matrix 120 is to start and knowledge about 
the speed and structure of the assembly line (and possibly other relevant data), the time when 
each particular order detailed in the order matrix 120 will enter the assembly line can be 
determined. If appropriate data concerning the assembly line stations is linked to the position 
and position variant information in the BOM, the time the parts indicated for use in accordance 
with the selected position variant for a given positions can also be determined. 
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Preferably, all rules in the code rule matrix 162 are evaluated for every order 
which is defined in the order matrix 120. When the evaluated rule data is mapped to the BOM 
(step 168), the time when a specific order enters the assembly line, and possibly when specific 
stations on the line are reached, is determined. This data is then used to determine whether at 
the particular manufacturing time for a given order, any selected variants are invalid, either 
because they have expired or are not yet valid. Any hits from rules determined to be invalid 
for a given order are prevented from being mapped into the MRP matrix 170. 

Advantageously, because the evaluated rule matrix 164 contains rule evaluations 
for every order, even if the variant is ultimately determined to be invalid, it is possible to 
change the sequence of customer orders in the MRP matrix 120 without having lo reevaluate 
the entire BOM 100, as is necessary in conventional MRP systems. If the sequence in which 
customer orders are listed in the order matrix 120 is changed, all that is needed to generate an 
updated MRP matrix 170 is to resequence the data in the evaluated rule bit matrix 166 to 
correspond to the resequenced order matrix 120 (e.g., by simply rearranging the data columns) 
and repeat the mapping of the evaluated code rules to the BOM (step 168) so that the new times 
when the resequenced orders will reach the various positions on the assembly line can be 
determined and the appropriate hits filtered out during the mapping process. 

Changes in the manufacmring sequence may be necessary for many reasons, 
including a sudden unavailability of parts as a result of, e.g., a strike. By eliminating the need 
to reevaluate the code rules in response to a change in manufacturing sequence, manufacmring 
sequence variations can be quickly and easily analyzed, perhaps as part of an automated 
process, to determine the optimum sequence of manufacturing and the effect in time, cost, etc., 
of various sequencing options before a paaicular sequence is selected. Further, the changed 
parts requirements which may result from an order resequencing can be quickly communicated 
to just-in-time or real-time parts suppliers to ensure that parts requirements are met, and also 
can be used to route needed parts to the appropriate assembly line stations, even if the change 
occurs mid-stream. 

Once the MRP matrix 170 has been generated from a BOM 100 and a group of 
customer orders 120, the specific types and amounts of parts and position variants required to 
manufacture each of the ordered cars can be determined and this data used in a wide variety of 
applications. (See Fig. 20.) Because, in one embodiment, each unique position in the BOM 
100 can be linked to a station on the assembly line, the MRP data generated according to the 
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above process can be used to route necessary parts to the correct stations on the assembly line 
so that they are present when needed and also to inform the line workers which parts to install 
to thereby fabricate a custom ordered car. Furthermore, the MRP data can be used to generate 
purchase order requests to part suppliers with sufficient accuracy to maintain a just-in-time or 
real-time inventory system at the manufacmring facility. Alternatively, the raw MRP data can 
be supplied directly to part suppliers, e.g., via the Internet, so that they can determine when 
parts must be supplied to the manufacmrer and the volume required. In addition, the MRP data 
can be used to determine a wide variet\' of manufacmring related information, such as the acmal 
cost to manufacmre each individual order, the time required to assemble each order, the cost 
of implementing manufacmring changes, etc. 

As discussed above, while the rules in the code rule matrix 162 can be evaluated 
in many ways, a novel method of evaluating the code rules so as to greatly increase the speed 
of evaluation has been developed. This method will be discussed with respect to the flow 
diagram of Figs. 21a. 22b, and 22 and the sample data matrixes in Figs. 23-24. 25a, 25b, and 
26-27. 

The fast code rule evaluation method begins with a code rule matrix 162 
containing each unique code rule, such as described previously. A sample code rule matrix 162 
containing four separate code rules is illustrated in Fig. 23. As discussed above, the components 
used to construct the code rules correspond to the code rule elements 124 used in the order 
matrix 120. Thus, for example, the code rule "10500" in Fig. 23 is "(245+551) • M154". 
With reference to the data in the sample order matrix illustrated in Fig, 13, code rule 10500 is 
true for a particular order if the customer has selected a 6*cylinder engine (code "M154") and 
either or both of a trip computer (code "245") and an alarm (code "55 T) are also selected. 

Once the code rule matrix 162 is provided, each unique code rule is then broken 
down into its constiment code rule elements 124 which are stored in an intermediate rule 
evaluation matrix (see Figs. 25a-25b). For example, the logical code rule elements 124 of the 
code rule "(245 -f 551) • M154" are "245", "551", and "M154", Although the code rule 
elements 124 can be extracted directly from the original code rule, preferably, complex code 
rules (i.e., those which contain both AND and OR operators), are first divided into simpler 
logical operations which contain only a single type of logical operator (step 210) and these 
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simpler components are then further broken into individual code rule elements (Figs. 21a-21b, 
step 212). 

A simplifying breakdown of the code rules in Fig. 23 is shown in the 
intermediate matrix 240 illustrated in Fig. 24. The sample source code rule "(245 + 551) • 
Mi54" of row 244 (rule ID 10500) has been divided into two simpler rule components, 
"245 • M154" (row 246) and "551 • M154" (row 248) according to the distributive property of 
boolean equations, thus eliminating the "OR" operator. 

Once a code rule has been broken down into simplified code rule components, 
the original code rule can be evaluated by first evaluating each of the derived simplified rule 
components and then combining the results appropriately. In this example, the code rule "(245 
-f 551) • M154" (row 244) is true if either of the derivative simplified rule components "245 
• M154" and "551 * M154" (rows 246. 248) is true. 

Alternatively, simplified rule components can be derived which eliminate the 
"AND" operator. In this example, the components would be "245 + 551" and M154. In such 
a case, the source code rule would be true only if both of the simplified rule components are 
true. The selection of whether to simplif>' code rules by eliminating AND operators or 
eliminating OR operators is dependent to some extent on the complexity of the code rules. 
Preferably, the selected simplification method is chosen in order to minimize the number of 
simplified rule components which are generated. In the present example, all simplified 
components result from elimination of the OR operators. However, in practice, some 
simplified rules can be generated from OR elimination while others are generated from AND 
elimination. 

The code rule and the derived simpler components (rows 244-248) can all be 
considered part of the same code rule record 242, and thus are assigned the same code rule ID. 
To distinguish the simplified rule components from the original unique code rules, the entries 
can be given different classes 252, i.e., class "V" and X*' respectively. Alternatively, or in 
conjunction, a numeric designation "CV2" 250 can be provided in which a code rule has value 
zero and the simplified components are numbered sequentially as shown. 

After the simplified code rule components are generated for a given code rule, 
the rule components are further divided into discrete code rule elements 124. Figs. 25a-25b 
show rule evaluation matrix 214 as it appears after all the code rules have been simplified and 
expanded. For example, code rule component 246 is divided into the discrete elements "245" 
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and "Ml 54" {rows 256 and 258) and code rule component 248 is divided into the discrete 
eJements "551" and "M154" (rows 260 and 262). These atomic code rule elements can be 
distinguished from simplified components and the original code rules by an appropriate class 
252 designation, such as "A". In addition, or alternatively, a second numeric designation 
254 can be used, wherein each simplified component has a CV3 value of zero and the 
associated code rule elements have a CVS value which is numbered sequentially. 

Once the rule evaluation matrix 214 has been generated, the code rules in the 
matrix 214 are evaluated for each customer order using the data from the order matrix 120. 
A discrete code rule element can be evaluated for every order very quickly and with minimal 
computing overhead simply by linking each discrete rule element record in the rule evaluation 
matrix 214 (i.e.. class "A" records) to the customer order data in the row in the order matrix 
120 which contains the same discrete rule element (Figs. 21a-21b. step 216). Advantageously, 
this technique eliminates any need to directly access data stored in the order matrix 120 for any 
particular customer order. Rather, each discrete code rule element is evaluated for all customer 
orders by the establishment of a single link. 

Fig. 26 illustrates this technique with a portion 214' of the intermediate rule 
evaluation matrix 214 of Figs. 25a-25b and a corresponding portion 120* of the order matrix 
120 of Fig. 13. As shown, row 256 of rule evaluation matrix 214' contains code rule element 
t.245" jhis ejjjjy linked to the data in row 266 in the order matrbc 120\ which data 
indicates for each of the customer orders whether that option has been selected. The resulting 
panially evaluated matrix can be visualized as an intermediate matrix 269 as shown in Fig. 26. 
Although the data rows from the order matrix 120' can be copied into an intermediate matrix, 
such as matrix 269, the data at this level is not modified during the rule evaluation and therefore 
copying is an uimecessary use of system resources, both in execution time and memory 
utilization. However, for the purposes of clarity, the order matrix data will be illustrated as 
if it were directly copied. 

Once the order matrix data has been linked to the discrete rule element entries 
in the rule evaluation matrix 214, the simplified code rule components are evaluated with 
reference to the linked values of the discrete code rule elements (Figs. 21a-21b, step 218) and 
then the unique code rules themselves are evaluated with reference to the evaluation of the 
simplified code rule components (Fig. 22, step 220). 
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Advantageously, because each of the simplified code rule components contains 
only a single logical operator, each component can be easily evaluated for every order by 
simply summing the binar>' data for that order linked to each of the discrete code rule elements. 
In other words, addition can be used as a simple substimte for performing direct logical 
evaluations. When the simplified rule component is based on only AND operations, the 
simplified code rule component is true if the resulting sum is equal to the number of discrete 
rule elements it contains. When the simplified rule component is based on only OR operations, 
the simplified code rule component is true if the resulting sum is greater than zero. 

A special case exists when a rule includes a NOT operator, i.e., a code rule such 
as "(245 + 551) ' -Ml 54". In one implementation, the NOT operation, as applied to a discrete 
rule element, is implemented by inverting the data in the linked order matrix row when it is 
referenced. Alternatively, when a discrete code rule element is to be inverted, true binary data 
values linked from the order matrix 120 are not considered to have a value of one, but instead 
are assigned a negative value which is sufficiently large (e.g., -9) to ensure that the generated 
sum can be properly interpreted when evaluating the simplified code rule element using 
addition. 

Fig. 27 is an illustration of an evaluated rule matrix 166 showing a single ftilly 
evaluated code rule in accordance with the intermediate matrix 269 shown in Fig. 26 and using 
addition to evaluate the simplified code rule components. As discussed above, order data for 
the discrete code rule elements (rows 256, 258, 260, and 262) are directly linked from the 
corresponding data rows in the order matrix 120, In this example, simplified rule component 
"245 • M154*' (row 246) is defmed to have a value for each order l..,n which is the sum of the 
values in each code rule element (rows 256, 258) for the respective order. Thus, the value of 
simplified rule component "245 • Ml 54" for order 1 is the sum 1+0 = 1, The value of this 
component for order 3 is the sum 1 + 1= 2, Because the simplified rule component is an AND- 
only rule with two elements,, the component is true only when the sum of the discrete rule 
element values equals 2, In this example, the simplified component is only true for order 3. 
The second simplified component (row 248) is evaluated similarly and is also true only for 
order 3, Once the simplified rule components are evaluated, the results are logically combined 
to evaluate the original code rule. Here, code rule 105(K) (row 244) is valid only for order 3. 

As can be appreciated, using the above technique, each unique code rule is 
essentially evaluated for all orders in the order matrix 120 in parallel. The use of simplified 
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code rule components allows some or all of the evaluation to be by simple addition operations. 
Although the individual additions must still be performed, conventional database programs are 
generally written to allow the value of one data row to be dependent on a mathematical 
combination of the values in other rows. Thus, this evaluation method can easily be integrated 
as a spreadsheet-type formula associated with each of the simplified rule component rows (e.g., 
row 246 = (row 256) -h (row 258)), In addition, the intermediate evaluations may be performed 
very quickly. 

It should be noted that while logical evaluation by addition is a preferred method 
of implementation, due to its ease of implementation in a spread-sheet type database system, 
the invention is not so limited. Thus, for example, the simplified code rule components can be 
evaluated directly as logical statements applied to appropriate bit matrixes, either within the 
database program itself, or by use of an external computer program (written in, e.g., "C" or 
assembly language), which program is passed the appropriate data matrixes as arguments. 

After all of the individual code rules have been evaluated, the results are then 
linked, copied, or otherwise mapped to the BOM 100 using the code rule IDs to thereby 
generate an MRP matrix 170 which indicates, for each customer order, which position variant 
is to be used at each defmed position. 

The simplified and parallel rule evaluation of the present invention permits an 
MRP analysis to be performed at speeds several orders of magnitude faster than conventional 
techniques. While a conventional MRP process may take upwards of 100 hours to evaluate a 
70,000 entry BOM for 8000 separate customer orders, a complete MRP evaluation using a 
system operated according lo the invention can be performed in substantially less than one hour 
and an MRP for a resequenced order matrix can be generated in a matter of seconds. 

It should be noted that while the various matrixes have been described above as 
being separate from each other, it is understood that they can be combined into one or more 
larger matrixes and data for the various rows and columns filled in as needed. Further, while 
the matrix representation is the preferred format, other data storage methods can also be used 
as appropriate for the particular computer operating environment at issue. 



SUBSTITUTE SHEET (RULE 2B) 



wo 00/13115 3Q PCT/EP99/06389 

Once a code rale has been broken down into simplified code rale 
components, the original code rale can be evaluated by first evaluating each of the derived 
sfanplified rale components and then combining the results appropriately. In this example, 
the code rale "(245 + 551) • M154" (row 244) is trae if either of the derivative 
5 simplified rale components "245 • M154" and "551 - M154" (rows 246, 248) is trae. 



Alternatively, simplified rale components can be derived which eliminate 
the "AND" operator. In this example, the components would be "245 -f- 551 " and M154. 
In such a case, the source code rale would be trae only if both of the simplified rule 

10 components are trae. The selection of whether to simplify code rales by eliminating AND 
operators or eiimmating OR operators is dependent to some extent on the complexity of 
the code rales. Preferably, the selected simplification method is chosen in order to 
minimize the number of simplified rale components which are generated. In the present 
example, all simplified components result from elimination of the OR operators. 

15 However, in practice, some simplified rales can be generated from OR elimination while 
others are generated from AND elimination. 

The code rale and the derived simpler components (rows 244-248) can all 
be considered part of the same code rale record 242, and thus are assigned the same code 
rale ID. To distinguish the simplified rale components from the original unique code 

20 rales, the entries can be given different classes 252, i.e., class "V" and "C" respectively. 
Alternatively, or in conjunction, a numeric designation "CV2" 250 can be provided in 
which a code rale has value zero and the snnplified components are numbered sequentially 
as shown. 

After the simplified code rale components are generated for a given code 
25 rale, the rale components are further divided into discrete code rale elements 124. Fig. 
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25 shows rule evaluation matrix 214 as it appears after all the code rules have been 
simplified and expanded. For example, code rule component 246 is divided into the 
discrete elements "245" and "M154" (rows 256 and 258) and code rale component 248 
is divided into the discrete elements "551" and "M154" (rows 260 and 262). These 
5 atomic code rule elements can be distinguished from shnpiified components and the 
original code rules by an appropriate class 252 designation, such as "A\ In addition, or 
alternatively, a second numeric designation "CVS" 254 can be used, wherem each 
simplified component has a CVS value of zero and the associated code rale elements have 
a CVS value which is numbered sequentially. 

10 Once the rale evaluation matrix 214 has been generated, the code rales in 

the matrix 214 are evaluated for each customer order ushag the data from the order matrix 
120. A discrete code rale element can be evaluated for every order very quickly and with 
minimal computing overhead simply by linking each discrete rale element record in the 
rale evaluation matrix 214 (i.e,, class "A" records) to the customer order data in the row 

15 in the order matrix 120 which contains the same discrete rale element (Fig. 21 , step 216). 
Advantageously, this technique eliminates any need to directly access data stored in the 
order matrix 120 for any particular customer order. Rather, each discrete code rale 
element is evaluated for all customer orders by the establishment of a single link. 

Fig, 26 illustrates this technique with a portion 214' of the intermediate rale 

20 evaluation matrix 2 14 of Fig. 25 and a corresponding portion 120' of the order matrix 120 
of Fig. 13. As shown, row 256 of rale evaluation matrix 214' contains code rale element 
"245". This entry is linked to the data in row 266 in the order matrix 120', which data 
mdicates for each of the customer orders whether that option has been selected. The 
resulting partially evaluated matrix can be visualized as an intermediate matrix 269 as 

25 shown in Fig. 26. Although the data rows from the order matrix 120' can be copied into 
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an intermediate matrix, such as matrix 269, the data at this level is not modified during 
the rule evaluation and therefore copying is an unnecessary use of system resources, both 
in execution time and memory utilization. However, for the purposes of clarity, the order 
matrix data will be illustrated as if it were directly copied, 
5 Once the order matrix data has been ImJced to the discrete rule element 

entries in the rule evaluation matrix 214, the simplified code rule components are 
evaluated with reference to the linked values of the discrete code rule elements (Fig. 21, 
step 218) and then the unique code rules themselves are evaluated with reference to the 
evaluation of the simplified code rule components (Fig, 22, step 220). 

10 Advantageously, because each of the simplified code rule components 

contains only a single logical operator, each component can be easily evaluated for every 
order by simply summing the binary data for that order linked to each of the discrete code 
rule elements. In other words, addition can be used as a simple substitute for performing 
direct logical evaluations. When the simplified rule component is based on only AND 

15 operations, the simplified code rule component is true if the resulting sum is equal to the 
number of discrete rule elements it contams. When the simplified rule component is 
based on only OR operations, the simplified code rule component is true if the resulting 
sum is greater than zero. 

A special case exists when a rule includes a NOT operator, i.e., a code rule 

20 such as "(245 -I- 551) • -M154". In one implementation, the NOT operation, as applied 
to a discrete rule element, is implemented by inverting the data in the linked order matrix 
row when it is referenced. Alternatively, when a discrete code rule element is to be 
inverted, true binary data values Imked from the order matrix 120 are not considered to 
have a value of one, but instead are assigned a negative value which is sufficiently large 
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(e.g., -9) to ensure that the generated sum can be properly interpreted when evaluating 
the simplified code rule element using addition. 

Fig. 27 is an illustration of an evaluated rule matrix 166 showing a single 
fully evaluated code rule in accordance with the intermediate matrix 269 shown in Fig, 

5 26 and using addition to evaluate the simplified code rule components. As discussed 
above, order data for the discrete code rule elements (rows 256, 258, 260, and 262) are 
directly linked from the corresponding data rows in the order matrix 120. In this 
example, simplified rule component "245 - M154" (row 246) is defined to have a value 
for each order l...n which is the sum of the values in each code rule element (rows 256, 

10 258) for the respective order. Thus, the value of simplified rule component "245 • 
M154" for order 1 is the sum 1+0=1. The value of this component for order 3 is the 
sum 1 + 1=2. Because the simplified rule component is an AND-only rule with two 
elements,, the component is true only when the sum of the discrete rule element values 
equals 2. In this example, the simplified component is only true for order 3. The second 

15 simplified component (row 248) is evaluated similarly and is also true only for order 3. 
Once the simplified rule components are evaluated, the results are logically combined to 
evaluate the original code rule. Here, code rule 10500 (row 244) is valid only for order 
3. 

As can be appreciated, using the above technique, each unique code rule 
20 is essentially evaluated for all orders in the order matrix 120 in parallel. The use of 
simplified code rule components allows some or all of the evaluation to be by simple 
addition operations. Although the individual additions must still be performed, 
conventional database programs are generally written to allow the value of one data row 
to be dependent on a mathematical combination of the values in other rows. Thus, this 
25 evaluation method can easily be integrated as a spreadsheet-type formula associated with 
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each of the simplified rule component rows (e.g., row 246 = (row 256)-i-(row 258)). In 
addition, the intermediate evaluations may be performed very quickly. 

It should be noted that while logical evaluation by addition is a preferred 
method of implementation, due to its ease of implementation in a spread-sheet type 
5 database system, the invention is not so limited. Thus, for example, the simplified code 
rule components can be evaluated directly as logical statements applied to appropriate bit 
matrixes, either within the database program itself, or by use of an external computer 
program (written in, e.g., "C" or assembly language), which program is passed the 
appropriate data matrixes as arguments. 
10 After all of the individual code rules have been evaluated, the results are 

then linked, copied, or otherwise mapped to the BOM 100 using the code rule IDs to 
thereby generate an MRP matrix 170 which indicates, for each customer order, which 
position variant is to be used at each defined position. 

The simplified and parallel rule evaluation of the present invention permits 
15 an MRP analysis to be performed at speeds several orders of magnitude faster than 
conventional techniques. While a conventional MRP process may take upwards of 100 
hours to evaluate a 70,000 entry BOM for 8000 separate customer orders, a complete 
MRP evaluation using a system operated according to the invention can be performed in 
substantially less than one hour and an MRP for a resequenced order matrix can be 
20 generated in a matter of seconds. 

It should be noted that while the various matrixes have been described 
above as being separate from each other, it is understood that they can be combined into 
one or more larger matrixes and data for the various rows and colurrms filled in as 
needed. Further, while the matrix representation is the preferred format, other data 



H 

m 
m 



a 
m 
a 



wo 00/13115 35 PCT/EP99/06389 

Storage methods can also be used as appropriate for the particular computer operating 
environment at issue. 
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1 . A method for representing an article of manufacture having a pluraht\' of 
structural design variants comprising the steps of: 

defining a plurality of positions (12) each corresponding to a different predefined 
location on the article of manufacture; and 

assigning at least one position variant (16) to each position, each position variant 
( 1 6) identif>'ing a specific part that may be used at the respective position ( 12) in accordance with 
a particular design variant, so that, in a particular article of manufacture, only one of the at least 
one position variants can be selected for the respective position. 

2. The method of claim 1 , further comprising the step of; 

defining a plurality of links (14) each between panicular pairs of positions, each 
link ( 1 4) corresponding to a physical connection between parts in a pair of locations in the article 
of manufacture, which pair of locations corresponds to the respective pair of positions. 

3. The method of claim 2. further comprising the step of: 

assigning at least one cormection variant (16) to each link (14), each connection 
variant (16) specifying a panicular method of joining a part in a first position of the respective pair 
of positions to a part in the other position of the respective pair of positions, 

4. The method of claim 2, further comprising the steps of: 
assigning at least one connection variant (16) to each link (14); 

assigning to each cormection variant (16) at least one of functional data, structural 
data, part supplier data, group membership data, and financial data. 

5. The method of claim I , further comprising the steps of: 
formulating a code rule (22) for each position variant (16) indicating when the 

particular variant (16) should be selected in accordance with specified design options; 

identifying the code rule (22) for each position variant ( 1 6) assigned to a specific 

position; 

determining any overlap in scope between the identified code rules (22); and 
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adjusting the identified code rules (22) lo remove at least some of the determined 

overlap. 

6. A nnethod for manufacturing an article of manufacture having a plurality 
of structural design variants comprising the steps of: 

defining a plurality of positions (12) each corresponding to a different predefined 
location on the anicie of manufacture: 

assigning each position a unique position ID; 

assigning at least one position variant (16) to each position, each position variant 
(16) identifying a specific pan that may be used at the location corresponding to the respective 
position and having a related code rule (22) indicating when the particular vanant ( 1 6) should be 
selected in accordance v^ith specified design options; 

upon receiving an order (56) containing specified design options: 

evaluating the code rule (22) for each position variant (16) to select a 
specific position variant for each position and thereby identify a specific part for use in the 
location corresponding to the respective position; 

providing the specific part associated with each selected position variant; 

and 

manufacturing the article of manufacture using the specific parts in the 
corresponding locations. 

7- The method of claim 6, further comprising the steps of: 
defining a plurality of links (14) each between particular pairs of positions (12), 
each link (14) corresponding to a physical connection between parts in a pair of locations in the 
article of manufacture, which pair of locations corresponds to the respective pair of positions ( 1 2); 
and 

assigning at least one connection variant (16) to at least one link (14), each 
connection variant (16) specifying a particular method of joining a first part in a first position of 
the respective pair of positions to a second part in the other position of the respective pair of 
positions, each connection variant (16) having a related code rule (22) indicating when the 
particular connection variant should be selected in accordance with specified design options. 
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8. The method of claim 7. further comprising the step of; 

evaluating the code rule (22) for each connection variant (16) to identify an 
appropriaie method of joining the identified parts for the corresponding pair of positions { 1 2) in 
response to the receipt of an order containing specified design options: and 

the manufacturing step comprising the step of using the identified method to join 
the respective identified pans. 

9. A method for determining manufacmring parts requirements to produce an 
article of manufacture ha\*ing a plurality of structural design variants in accordance with at least 
one order (1 56) specify ing particular design options, the article of manufacture being described 
in a bill of materials (BOM) (100) containing a plurality of position variant definitions (16), each 
position variant definition (16) being assigned to a particular position (12) corresponding to a 
physical location in the article of manufacture, each position variant (16) funher identifying a 
specific part and including a code rule (22) indicating when the identified part should be used at 
the location corresponding to the particular position (12), the method comprising the steps of: 

extracting unique code rules from the BOM (101); 

evaluating eacii unique code rule in accordance with the design options for each 

order (156): 

mapping the evaluations of the imique code rules to the corresponding code rules 
(22) in the position variant definitions ( 1 6) in the BOM ( 1 00); and 

determining the appropriate position variant (1 6) to select for each position (12) 
in accordance with the mapped code rule evaluations. 

1 0. The method of claim 9, wherein: 

each code rule (22) comprises at least one code rule element (1 24) corresponding 
to a selectable design option (122); and 

the orders ( 1 56) are contained in an order matrix ( 1 20) which cross references each 
order against every code rule element. 

1 1 . The method of claim 1 0, wherein the step of evaluating each unique code 
rule comprises the steps of: 

dividing each imique code rule into its discrete code rule elements (124); 
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linking each discrete code rule element ( 1 24) with order data for the corresponding 
code rule element in the order matrix ( 1 20); and 

evaluating each unique code rule (22) in accordance with the order data linked to 
the associated discrete code rule elements (124). 

12- The method of claim 1 1. wherein the step ofdividing each unique code rule 
comprises the steps of: 

factoring each unique code rule into one or more simpler code rule components; 

and 

dividing each code rule component into one or more discrete code rule elements 

(124): and 

the step of evaluating each unique code rule further comprising the steps of: 

evaluating each code rule component in accordance with the order data 
linked to the associated discrete code rule elements (124); and 

evaluating each unique code rule in accordance with the e\'aluated code rule 

components, 

13. The method of claim 10, wherein each position variant (16) has an 
associated vaiidit>' period and the step of extracting unique code rules comprises extracting imique 
code rules only from those position variants (16) which have not expired at a specified start time 
based on the validity period. 

14, The method of claim 1 3, wherein a sequence of orders in the order matrix 
(120) indicates a time sequence of manufacture, the method further comprising the steps of 
determining, in accordance with the specified start time, a build time when the article of 
manufacture associated with each particular order will be manufactured; 

the step of mapping comprising mapping the evaluations of the imique code rules 
to the corresponding code rules (22) in the position variant definitions (16) only for those 
particular orders which have a build time v^thin the validity period of the respective position 
variant. 
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15. The method of claim 13. further comprising the step of repealing the 
mapping step upon receipt of a resequenced order matrix to determine revised manufacturing parts 
requirements in accordance with the resequenced matrix. 

1 6. A method for generating documentation for an article of manufacture 
having plural structural design variations comprising the steps of: 

defining a piuraiit>' of positions (12) each corresponding to a different predefined 
location on the article of manufacturei 

assigning at least one position variant (16) to each position (12), each position 
variant identifying a specific part that may be used at the location corresponding to the respective 
position in accordance with a particular design variation, so that* in a panicuiar article of 
manufacture, only one of the at least one position variants can be assigned to the respective 
position; 

assigning component documentation data to a predetermined set of position 

variants (16); 

defining at least one assembly to be documented, said assembly comprising a 
plurality of positions (12) and having a plurality of design variants (16): 

upon receipt of a customer order (156) specifying selected design options: 

determining the specific assembly design variant defined by the selected 

design options, 

aggregating the documentation data assigned to the positions in the assembly, and 
storing the aggregated documentation data. 

17. The method of claim 16, fiirther comprising the steps of assigning 
connection documentation data to iirUcs (14) between pairs of positions (12); and 

the step of aggregating further comprises the step of aggregating documentation 
data assigned to links (14) between pairs of positions (12) in the assembly. 

18. A system for generating a bill of materials (BOM) (100) representing the 
parts used in an article of manufacture having a plurality of structural design variants comprising: 

a computer having a processor and a memory; 

the memory containing computer code configuring the processor to: 
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receive a plurality of position definitions (12) each corresponding to a 
different predefined location on the article of manufacture; 

receive assignments of at least one position variant (1 6) to each position 
{ 1 2). each position variant ( 1 6) identifying a specific part that may be used at the location 
corresponding to the respective position in accordance with a particular design variant, 
each position variant ( 1 6) further including a code rule (22) indicating when the particular 
variant should be selected in accordance with specified design options; 

identify the code rules (22) for each position variant (16) assigned to a 

specific position: 

determine any overlap in scope beu\'een the identified code rules; 

adjust the identified code rules (22) to remove at least some of the 
determined overlap: 

generate a BOxM ( 1 00 ) including said plurality of positions (12), assigned 
position variants (16). and adjusted code rules (22); and 

store said BOM (100) for use in determining manufacturing parts 
requirements for producing particular design variants of said article of manufacmre. 

19. A system for use in manufacturing an article of manufacture ha\ ing a 
plurality of structural design variants, the system comprising: 
a computer having a processor and a memory; 

the memory including information representing a bill of materials (BOM) (100) 
containing a plurality of position variant definitions (16), each position variant definition (16) 
being assigned to a particular position (12) corresponding to a location in the article of 
manufacture, each position variant definition ( 1 6) fiather identifying a specific part, and including 
a code rule (22) indicating when the position variant ( 1 6) should be selected and thereby when the 
identified part should be used at the corresponding location; 

the memoiy further including information representing at least one order (154) 
specifying particular design options which define a particular design variant of the article; 
the processor being configured to: 

(a) evaluate the code rules (22) for each position variant ( 1 6) in accordance 
with the respective design options for each order (1 56) to identify an appropriate part for 
use in each location of the corresponding particular design variant of the article; and 
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(b) produce an output indicating for each order ( 1 56) the appropriate parts 
for use in the corresponding particular design variant of the article: 

the particular design variant defined by a specific order being manufactured using 
the parts indicated for that specific order. 

20 . The system of claim 1 9 . wherein the processor is configured to evaluate the 

code rules by: 

extracting unique code rules from the BOM (100): 

evaluating each unique code rule in accordance with the design options for each 

order (156); 

mapping the evaluations of the unique code rules to the corresponding code rules 
in the position variant definitions (1 6) in the BOM (100): and 

determining the appropriate position variant (16) to select for each position (12) 
in accordance with the mapped code rule evaluations. 

21 . The system of claim 20. wherein: 

each code rule (22) comprises at least one code rule element; 
each design option corresponds to a respective code rule element (124); and 
the orders ( 1 56) are contained in an order matrix ( 1 20) which cross references each 
order (1 56) against the code rule elements (124); 

the processor being further configured to evaluate each unique code rule by: 

dividing each unique code rule into its discrete code rule elements (124); 
linking each discrete code rule element (124) with order data for the 
corresponding code rule element in the order matrix (120); and 

evaluating each unique code rule in accordance with the order data linked 
to the associated discrete code rule elements (124), 

22. The system of claim 2 1 , wherein: 

the processor is configured to divide each unique code rule by factoring each 
unique code rule into simpler code rule components and dividing the code rule components into 
discrete code rule elements (124); 
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the processor being ftirther configured to evaluate each code rule component in 
accordance with the order data linked to the associated discrete code rule elements (124) and 
evaluate each unique code rule (22) in accordance with the evaluated code rule components. 

23. The system of claim 20, wherein each position variant has an associated 
vaiidit}" period: and 

the processor is configured to extract unique code rules only from those position 
variants (16) which are not expired at a specified start time in accordance with the associated 
validit}* period. 



24. The system of claim 23, wherein: 

the orders ( 1 56) are contained in an order matrix ( 1 20) stored in memory wherein 
the sequence of orders in the order matrix (120) indicates a time sequence of manufacture of said 
orders; 

the processor being further configured to: 

determine, in accordance with the specified stan time, a build time when 
the article of manufacture associated with each particular order will be manufactured; and 
map the evaluations of the imique code rules to the corresponding code 
rules (22) in the position variant definitions (16) only for those particular orders (156) 
which have a build time v^thin the validity period of the respective position variants. 

25. The system of claim 23, wherein the processor is configured to repeat the 
mapping procedure upon receipt of a resequenced order matrix to thereby provide revised 
manufacturing parts requirements in accordance with the resequenced order matrix. 

26. A data structure for storing in a computer readable medium a representation 
of an article of manufacture having plural structural design variants, the data structure comprising: 

a plurality of data positions (12), each corresponding to a predefined location in 
the article of manufacture; 

at least one position variant (16) assigned to each position (12), each poshion 
variant (16) including a first field containing part identification data (102) and a second field 
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containing a code rule (22), the code rule indicating when the part identified in the first field is to 
be placed in the location associated with the respective position (12). 

27. The data structure of claim 26. further comprising: 

at least one link (14) between a first position and a second position, the link 
indicating a physical connection between a first pan at a first location associated with the first 
position and a second part at a second location associated with the second position: 

at least one connection variant (16) assigned to each link (14). each connection 
variant including a first field containing process information related to the joining of the first pan 
and the second part and a second field containing a code rule (22). the code rule (22) indicating 
when the process information in the first field is appropriate for use in assembling a panicular 
design variant of the article of manufacture. 

28. The data suncture of claim 26. fiirther comprising: 

a plurality of links (14) each between a respective first position and a respective 
second position, each link indicating a physical connection between a first pan at a first location 
associated with the respective first position and a second pan at a second location associated with 
the respective second position; 

each connection variant including a group identifier field (18) associating the 
respective first and second positions with a particular group of positions. 

29. A computer program for representing an article of manufacmre having a 
plurality of structural design variants, said program being stored on a storage medium and 
comprising: 

a program module defining a plurality of positions (12) each corresponding to a 
different predefined location on the article of manufacture; and 

a program module assigning at least one position variant ( 1 6) to each position, each 
position variant ( 1 6) identifying a specific part that may be used at the location corresponding to 
the respective position (12) in accordance with a particular design variant, so that in a particular 
article of manufacture, only one of the at least one position variants can be selected for the 
respective position. 
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30. The computer program of claim 29. further comprising a program module 
defining a pluraiit\' of links (14) between particular pairs of positions (12), each link (14) 
con^esponding to a physical connection between pans m a pair of locations in the article of 
manufacture, which pair of locations corresponds to the respective pair of positions. 

3 1 . The computer program of claim 30. further comprising a program module 
assigning at least one connection variant (16) to each link (14), each connection variant (16) 
specifying a particular method of joining a part in a first position of the respective pair of positions 
to a pan in the other position of the respective pair of positions. 

32. The computer program of claim 30, further comprising: 

a program module assigning at least one connection variant ( 1 6) to each link (14): 

and 

a program module assigning to each connection variant (16) at least one of 
functional data, structural data, part supplier data, group membership data, and financial data. 

33. The computer program of claim 29, further comprising: 

a program module receiving a code rule (22) for each position variant (16) 
indicating when the particular variant should be selected in accordance with specified design 
options; 

a program module identifying the code rules (22) for each position variant (16) 
assigned to a specific position (12); 

a program module determining any overlap in scope between the identified code 

rules; and 

a program module adjusting the identified code rules to remove at least some of 
the determined overlap. 

34. A computer program for manufacturing an article of manufacture having 
a plurality of strucniral design variants, said computer program being stored on a storage medium 
and comprising: 

a program module defuiing a plurality of positions (12) each corresponding to a 
different predefined location on the article of manufacture; 
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a program module assigning each position a unique position ID; 

a program module assigning at least one position variant ( 1 6) to each position ( 1 2), 
each position variant (16) identifying a specific part that may be used at the location 
corresponding to the respective position and having a related code rule (22) indicating when the 
panicular variant should be selected in accordance with specified design options; 

a program module which, upon receiving an order (156) containing specified 

design options: 

evaluates the code rules (22) for each position variant (16) to identify an 

appropriate part for use in each position: 

provides the specific part associated with each position variant (16): and 
controls manufacture of the article of manufacture, using the specific part 

in the corresponding location. 

35 . The computer program of claim 34, further comprising: 

a program module defining a plurality of links (14) each between particular pairs 
of positions (12), each link corresponding to a physical connection between parts in a pair of 
locations in the article of manufacture, which pair of locations corresponds to the respective pair 
of positions; and 

a program module assigning at least one connection variant ( 1 6) to at least one link 
(14), each connection variant (16) specifying a particular method of joining a first part in a first 
position of the respective pair of positions to a second part in the other position of the respective 
pair of positions, each connection variant ( 1 6) having a related code rule (22) indicating when the 
particular connection variant should be selected in accordance with specified design options. 

36. The computer program of claim 35, fiirther comprising: 

a program module evaluating the code rules (22) for each connection variant ( 1 6) 
to identify an appropriate method of joining the identified parts for the corresponding pair of 
positions in response to the receipt of an order (156) containing specified design options; and 

the manufacturing program module using the identified method to join the 
respective identified parts. 
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37. A computer program for determining manufacturing pans requirements to 
produce an article of manufacture having a plurality of structural design \'ariants in accordance 
with at least one order ( 1 56) specift^ing panicuiar design options, the anicle of manufacture being 
described in a bill of materials (BOM) (100) containing a plurality of position variant definitions 
(16), each position variant definition being assigned to a panicuiar position (12) corresponding 
to a location in the article of manufacture, each position variant further identifying a specific part 
(102) and including a code rule (22) indicating when the identified part should be used at the 
location corresponding to the associated position, the computer program being stored on a storage 
medium and comprising: 

a program module extracting unique code rules from the BOM (100); 

a program module evaluating each unique code rule in accordance v^ith the design 
options for each order; 

a program module mapping the evaluations of the unique code rules to the 
corresponding code rules (22) in the position variant definhions (16) in the BOM (100); and 

a program module determining the appropriate position variant (16) to select for 
each position (12) in accordance uith the mapped code rule evaluations. 

3 8. The computer program of claim 37. v^^herein each code rule (22) comprises 
at least one code rule element (124) corresponding to a selectable design option (126) and the 
orders (156) are contained in an order matrix (120) which cross references each order (1560 
against the code rule elements (124). 

3 9. The computer program of claim 38, v/herein the program module evaluating 
each unique code rule further comprises: 

a program module dividing each unique code rule into its discrete code rule 
elements (124); 

a program module linking each discrete code rule element (124) with order data 
for the corresponding code rule dement (124) in the order matrix (120); and 

a program module evaluating each unique code rule in accordance v^th the order 
data linked to the associated discrete code rule elements (124). 
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40. The computer program of claim 39, wherem the program module dividing 
each unique code rule comprises: 

a program module factoring each unique code rule into simpler code rule 
components (124); and 

a program module dividing the code rule components mto discrete code rule 

elements; and 

the program module evaluating each unique code rule further comprisine: 

a program module evaluating each code rule component in accordance vmh 

the order data linked to the associated discrete code rule elements (124); and 

a program module evaluating each unique code rule in accordance with the 

evaluated code rule components. 

4 1 . The computer program of claim 3 8, wherein each position variant ( 1 6) has 
an associated validity period and the program module extracting unique code rules comprises a 
program module for extracting unique code rules only from those position variants (16) which 
have not expired at a specified start time in accordance with the validity period, 

42. The computer program of claim 4 1 , wherein a sequence of orders ( 1 56) in 
the order matrix (120) indicates a time sequence of manufacture of said orders, the progimi 
further comprising: 

a program module determining, in accordance with the specified start time, a build 
time when the article of manufacture associated w^th each particular order will be manufactured; 
and 

the mapping program module comprises a module mapping the evaluations of the 
unique code rules to the corresponding code rules (22) in the position variant defmitions ( 1 6) only 
for those particular orders (154) which have a build time within the validity period of the 
respective position variant. 

43. The computer program of claim 4 1 , further comprising a program module 
repeating the mapping step upon receipt of a resequenced order matrix to determine revised 
manufacturing parts requirements in accordance with the resequenced order matrix. 
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44. A computer program for generatmg documentation for an article of 
manufacture having plural structural design variants, the computer program being stored in a 
storage medium and comprising: 

a program module defining a plurality of positions (12) each corresponding to a 
different predefined location on the article of manufacture; 

a program module assigning at least one variant ( 1 6) to each position, each variant 
(16) identifying a specific pan (102) that may be used at the location corresponding to the 
respective position (12) in accordance with a particular design variant, so that, in a particular 
anicle of manufacture, only one of the at least one position variants (16) can be selected for the 
respective position (12): 

a program module assigning component documentation data to at least panicuiar 
ones of the position variants (16); 

a program module defining at least one assembly to be documented, each assembly 
comprising a plurality of positions (12) and having a plurality of design variants (16); 

a program module which, upon receipt of a customer order (154) specifying 
selected design variants: 

determines the specific assembly design variant defined by the customer 

order, 

aggregates the documentation data assigned to the positions in the 

assembly, and 

stores the aggregated documentation data. 

45 . The computer program of claim 44, further comprising a program module 
assigning connection documentation data to links (14) between pairs of positions (12); and 

the program module for aggregating further comprising a program module for 
aggregating documentation data assigned to links (14) between positions (12) in the assembly. 
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certificate or of any PCT international application(s) designating at least one country other than the United States of America listed below 
and have also identified below any foreign application(s) for patent or inventor's certificate or any PCT international application(s) 
designating at least one country other than the United States of America filed by me on the same subject matter having a filing date 



before that of the application(s) of which priority is claimed: 


PRIOR FOREIGN/PCX APPLICATION(S) AND ANY PRIORITY CLAIMS UNDER 35 U.S.C. 119: 


COUNTRY 
(If PCT indicate PCT) 


APPLICATION NUMBER 


DATE OF FILING 
(day, month, year) 


PRIORITY CLAIMED 
UNDER 35 TJ.S.C. 119 


US 


60/098,788 


01 September 1998 


[X] YES DnO 








Q YES n NO 








□ YES D NO 








□ yes D no 








n YES D NO 
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(Includes Reference to PCX InternalBonal ApplidationsI 



ATTY'S DOCKET NUMBER 

3634/01360 



I hereby claim the benefit under Title 35, United States Code, §120 of any United States application(s) or PCT international 
application(s) designating the United States of America that is/are listed below and, insofar as the subject matter of each of the 
claims of this application is not disclosed in that/those prior application(s) in the manner provided by the first paragraph of Title 35, 
United States Code §112, I acknowledge the duty to disclose material information as defined in Title 37, Code of Federal 
Regulations, §1. 56(a) which occurred between the filing date of the prior application(s) and the national or PCT international filing 
date of this application: 



PRIOR U.S. APPLICATIONS OR PCT INTERNATIONAL APPLICATIONS DESIGNATING THE U.S. FOR BENEFIT UNDER 
35U.S.C. 120: 



U.S APPLICATIONS 



STATUS (Check one) 



U.S APPLICATION NUMBER 



U.S, FILING DATE 



PATENTED 



PENDING 



ABANDONED 



PCT APPLICATIONS DESIGNATING THE U.S. 



PCT APPLICATION NO 



PCT FILING DATE 



U S SERIAL NUMBER 
ASSIGNED {if any) 



PCT/EP99/06389 



31 August 1999 



POWER OF ATTORNEY: As a named inventor, I hereby appoint the following attorney(s) and/or agents to prosecute this application and 
transact all business in the Patent and Trademark Office connected therewith. Morris Relson #1^/108, Gordon D. Coplein #19J65, 
William F. Dudine, Jr. # 20.569 , Michael J. Sweedler #1 9,937 , S. Peter Ludwig # 25,351, Paul Fields # 20,298, Joseph B. Lerch 
# 26,936 , Melvin C. Garner #26^27^, Ethan Horwitz # 27,646 , Beverly B. Goodwin #28,417, Adda C. Gogoris # 29,714, Martin E. 
Goldstein # 20,869 , Bert J. Lewen 19,407 , Henry Sternberg # 22,408 , Peter C. Schechter #31j6fi2, Robert Schaffer # 31,194,. David R. 
Francescani # 25,1 5,9l Robert C. Sullivan, Jr. # 30,499 , and Joseph R. Robinson # 33,448 , Walt Thomas Zielinski # 1 8,902, E ugene L. 



Send Correspondence to: 

Brenenson, Chanah, Esq. 

DARBY & DARBY P.C. 

805 Third Avenue 

New York. New York 10022-7513 


Direct Telephone Calls to: 

{name and telephone number) 

(212)527-7700 

Chanah Brenenson, Esq. 


2 


FULL NAME 
OF INVENTOR 


FAMILY NAME 
KROGER 


FIRST GIVEN NAME 

Udo 


SECOND GIVEN NAME 


0 


RESIDENCE & 
CITIZENSHIP 


CITY 

Hamburg 


STATE OR FOREIGN COUNTRY CNC X 

Germany H^x^rv 


COUNTRY OF CITIZENSHIP 

Germany 


1 


POST OFFICE 
ADDRESS 


POST OFFICE ADDRESS 
Fischbeker Holtweg 116 


CITY 

H^mbujig 


STATE & ZIP CODE/COUNTRY 

D-21149, Germany 


2 


FULL NAME 
OF INVENTOR 


FAMILY NAME 
MONKE 


FIRST GIVEN NAME 
^Eokhard 


SECOND GIVEN NAME 


0 


RESIDENCE & 
CITIZENSHIP 


CITY 

Langwedel 


STATE OR FOREIGN COUNTRY 
Germany 


COUNTRY OF CITIZENSHIP 

Germany 


2 


POST OFFICE 
ADDRESS 


POST OFFICE ADDRESS 
tm Neuen Feld 31 


CITY 

Langwedel 




STATE S ZIP CODE/COUNTRY 

D-27299, Germany 


2 


FULL NAME 
OF INVENTOR 


FAMILY NAME 


FIRST GIVEN NAME 


SECOND GIVEN NAME 


0 


RESIDENCE & 
CITIZENSHIP 


CITY 


STATE OR FOREIGN COUNTRY 


COUNTRY OF CITIZENSHIP 


3 


POST OFFICE 
ADDRESS 


POST OFFICE ADDRESS 


CITY 


STATE & ZIP CODE/COUNTRY 




I hereby 
belief ar 
like so n 
such wil 


declare that all statements made herein of my own knowledge are true and that all statements made on information and 
s believed to be true; and further that these statements were made with the knowledge that willftil false statements and the 
lade are punishable by fine or imprisonment, or both, under section 1001 of Title 18 of the United States Code, and that 
Iful false statements may jeopardize the validity of the application or any patents issuing thereon. 


SIGNATURE OF INVENTOR 201 


SIGNATURE OF INVENTOR 202 


SIGNATXJRE OF INVENTOR 203 


DATE 


DATE 


DATE 
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